SlideShare a Scribd company logo
Ansible is the
simplest way to
automate.
Alexander Schedrov aka sanchiz
Team Lead, DevOps Engineer, FFW
MoldCamp 2015
Alexander Schedrov
aka sanchiz
Team Lead, DevOps Engineer,
FFW (ex ProPeople)
I love Open Source
I'm contributor to Open Source
That’s why I’m here
Ukraine, Kyiv
How it was earlier
Developers wrote code
SysAdmins deployed code and
configure servers
until one day… DevOps and Ansible
What is Ansible
Ansible is a radically simple IT
automation engine.
Ansible
• Clear - Ansible uses a simple syntax (YAML).
• Fast - Fast to learn and fast to set up.
• Complete - You have everything you need in one
complete package.
• Efficient - No extra software on your servers. Extensible
with modules on any programming language.
• Secure - Ansible uses SSH and requires no extra open
ports or daemons
Ansible vs Shell scripts
# Install the PGP key
gpg --keyserver keyserver.ubuntu.com --recv-keys 561F9B9CAC40B2F7
gpg --armor --export 561F9B9CAC40B2F7 | apt-key add -
# Install https support for apt
apt-get install apt-transport-https -y
# Add the passenger apt repository
echo "deb https://oss-binaries.phusionpassenger.com/apt/passenger
raring main" > /etc/apt/sources.list.d/passenger.list
chown root: /etc/apt/sources.list.d/passenger.list
chmod 600 /etc/apt/sources.list.d/passenger.list
# Update the apt cache so we can use the new repo
apt-get update
# Install nginx
apt-get install nginx-full passenger -y
# Set up passenger in the nginx configuration
sed -i "s/# passenger_root/passenger_root/" /etc/nginx/nginx.conf
sed -i "s/# passenger_ruby/passenger_ruby/" /etc/nginx/nginx.conf
# Start nginx
service nginx restart
Shell script
---
- hosts: all
tasks:
- name: Ensure the PGP key is installed
apt_key: id=AC40B2F7 state=present url="http://keyserver.ubuntu.com/
pks/lookup?op=get&fingerprint=on&search=0x561F9B9CAC40B2F7"
- name: Ensure https support for apt is installed
apt: pkg=apt-transport-https state=present
- name: Ensure the passenger apt repository is added
apt_repository: state=present repo='deb https://oss-
binaries.phusionpassenger.com/apt/passenger raring main'
- name: Ensure nginx is installed
apt: pkg=nginx-full state=present
- name: Ensure passenger is installed
apt: pkg=passenger state=present update_cache=yes
- name: Ensure the nginx configuration file is set
copy: src=/app/config/nginx.conf dest=/etc/nginx/nginx.conf
- name: Ensure nginx is running
service: name=nginx state=started
Ansible script
Why do we love Ansible
• It perfectly fit into our infrastructure
• It has a lot of modules and roles
• Can easily be executed on multiple servers
• Popular system
Installation
sudo pip install ansible
*nix
Packages: python-pip and python-devel
Windows
• Cywgin
• PyYAML
• Jinja2
• …
https://servercheck.in/blog/running-ansible-within-windows
What next?
3 main shell commands
• ansible-doc [options] [module...]
• ansible-playbook playbook.yml [options]
• ansible <host-pattern> <command> [options]
Additional commands
• ansible-galaxy [init|info|install|list|remove] [--help] [options]
• ansible-lint playbook.yml [options]
• ansible-pull [options] [playbook.yml]
• ansible-vault [create|decrypt|edit|encrypt|rekey] [--help]
[options] file_name
Playbook
What is playbook
Ansible playbook it’s a list of commands or
roles that will be executed on remote or local
machine.
What is Ansible role
Ansible role is clean, reusable abstraction
that provides certain functionality.
---
- hosts: all
# Get facts about hosts(OS, user and so on)
gather_facts: no
remote_user: root
vars_prompt:
# Variables that need should be entered
vars:
# List of variables
var_files:
# List of files with variables
roles:
# List of roles that should be included
pre_tasks:
# List of pre-tasks
tasks:
# List of main tasks
post_tasks:
# List of post-tasks
handlers:
# List of handlers
Ansible task
- name: Install libraries
apt: pkg={{ item }} state=installed
with_items:
- git
- apache2
- php5
- php5-mysql
Comment/Documentation
Module
Item
Iterate through array
Run playbook on remote
machine
Host Guest
192.168.1.1 192.168.1.2
Playbook on host
192.168.1.2
Run playbook on local
machine
Host
192.168.1.1
Playbook on host
192.168.1.1
Inventory
# Group name
[localhost]
# Hosts in group
127.0.0.1
# Group name
[mysql_group]
# Hosts in group
mysqlserver.com
192.168.1.1
# Group vars
[mysql_group:vars]
ansible_ssh_user=root
ansible_ssh_port=2222
/etc/ansible/hosts or ./hosts
Requirements: connection by ssh without password.
Ansible uses
templates
Jinja2.
---
- host: lamp_local
vars:
vhost_core_path: “/var/www/site.dev"
domain: "site"
tasks:
- name: Add Apache virtualhost for development.
template:
src: "templates/vhost.dev.conf.j2"
dest: "/etc/apache2/sites-available/{{ domain }}.dev.conf"
owner: root
group: root
mode: 0644
vhost.dev.conf.j2
<VirtualHost *:80>
ServerAdmin webmaster@localhost
ServerName {{ domain }}.192.168.60.25.xip.io
ServerAlias www.{{ domain }}.192.168.60.25.xip.io
DocumentRoot {{ vhost_core_path }}
<Directory "{{ vhost_core_path }}">
Options FollowSymLinks Indexes
AllowOverride All
</Directory>
</VirtualHost>
Ansible keeps things
organized
Roles
---
- hosts: webservers
roles:
- jenkins
- webservers
roles/jenkins
Use includes
---
- hosts: mysql_group
sudo: yes
vars_files:
- solr_vars.yml
pre_tasks:
- include: pre_tasks.yml
tasks:
- { include: deploy.yml, user: admin, ssh_keys: [ 'keys/
one.txt', 'keys/two.txt' ] }
handlers:
- include: handlers/handlers.yml
Migrate to Ansible
Just run shell scripts through Ansible
- name: Deploy system module
sudo: yes
shell: /usr/bin/deploy -t -v --tags=system
Start from small changes
Where we use Ansible
1. Configuration management
and infrastructure orchestration
Apahce, MySQL,
PHP
Ansible is the simplest way to automate. MoldCamp, 2015
Dev Test
ProdLocal developer's server
2. Deployments and builds
Our approach
• Code Driven Development
• Deployments and builds should be automated
• We should test each feature before merging into
master
• Everything that may be automated - should be
automated
Simple and efficient way
ansible-playbook [filename]
How do we generate builds
• GitHub Pull Requests to inject new features to
master branch
• Jenkins triggers ansible script within repo
• Ansible playbook download database from
production
• Ansible playbook apply changes to database
3. Provisioner for Vagrant
PUPHPET
One day our Vagrantbox is
died
Vagrant + Ansible = ♥
Provisioning. Vagrant.
Vagrant.configure(VAGRANTFILE_API_VERSION) do |config|
config.vm.box = "ubuntu/trusty64"
config.vm.network :private_network, ip: "192.168.60.77"
config.vm.network :forwarded_port, host: 4567, guest: 80
config.vm.provision "ansible" do |ansible|
ansible.playbook = "playbook.yml"
end
end
Vagrantfile:
Meet the CIBox
https://github.com/propeoplemd/cibox
Kudos to @podarok,@ygerasimov, @m1r1k and other
contributors
CIBox uses Ansible for:
• Provisioning in CI server (Jenkins)
• Provisioning in Vagrantbox
• GitHub Pull Request builder
Conclusion
• Ansible is a promising technology
• Easy to start
• It solves 95% of our DevOps
problems
• Ansible is awesome and we love it
Thank you!
GitHub: https://github.com/Sanchiz
Blog: http://sanchiz.net
Email: alexander.schedrov@gmail.com
Twitter: @alexschedrov
Drupal.org: https://www.drupal.org/u/sanchiz

More Related Content

PPTX
Ansible presentation
PDF
Automation with ansible
PPT
Ansible presentation
PPTX
Introduction to ansible
PDF
#OktoCampus - Workshop : An introduction to Ansible
PDF
IT Automation with Ansible
PPTX
Introduction to Ansible
ODP
Ansible basics workshop
Ansible presentation
Automation with ansible
Ansible presentation
Introduction to ansible
#OktoCampus - Workshop : An introduction to Ansible
IT Automation with Ansible
Introduction to Ansible
Ansible basics workshop

What's hot (20)

PDF
DevOpsDaysCPT Ansible Infrastrucutre as Code 2017
PDF
Ansible - Swiss Army Knife Orchestration
PDF
Ansible Automation to Rule Them All
PDF
Ansible roles done right
PDF
Configuration Management in Ansible
PPTX
Using Ansible Dynamic Inventory with Amazon EC2
ODP
ansible why ?
PDF
Ansible - Introduction
PPTX
Ansible - Crash course
PDF
Ansible tips & tricks
PPTX
Ansible presentation
PPTX
Best practices for ansible
PDF
Introducing Ansible
PDF
Ansible Meetup Hamburg / Quickstart
PPTX
Ansible Automation Best Practices From Startups to Enterprises - Minnebar 12
PDF
Ansible, best practices
PPTX
Ansible for beginners
PDF
Jenkins and ansible reference
PDF
Ansible Introduction - Ansible Brno #1 - David Karban
PDF
Ansible for beginners ...?
DevOpsDaysCPT Ansible Infrastrucutre as Code 2017
Ansible - Swiss Army Knife Orchestration
Ansible Automation to Rule Them All
Ansible roles done right
Configuration Management in Ansible
Using Ansible Dynamic Inventory with Amazon EC2
ansible why ?
Ansible - Introduction
Ansible - Crash course
Ansible tips & tricks
Ansible presentation
Best practices for ansible
Introducing Ansible
Ansible Meetup Hamburg / Quickstart
Ansible Automation Best Practices From Startups to Enterprises - Minnebar 12
Ansible, best practices
Ansible for beginners
Jenkins and ansible reference
Ansible Introduction - Ansible Brno #1 - David Karban
Ansible for beginners ...?
Ad

Viewers also liked (18)

PDF
Ansible
PDF
Ansible Introduction
PDF
DevOps in the Cloud with Microsoft Azure
PDF
Using Groovy with Jenkins
PPTX
DevOps, A brief introduction to Vagrant & Ansible
PPT
Chef Delivery
PPT
Puppets
PPTX
Introduction to chef
PDF
Survey: Frozen Yogurt Market in India (2013)
PDF
Compliance Automation Workshop
PDF
Chef vs Puppet vs Ansible vs SaltStack | Configuration Management Tools Compa...
PDF
Chef Fundamentals Training Series Module 6: Roles, Environments, Community Co...
PPTX
STIG Compliance and Remediation with Ansible
PDF
Puppet overview
PPTX
Infrastructure Automation with Chef
ODP
Introduction to Chef
PDF
Introduction to puppet
PPTX
3 Steps to Expand DevOps and Automation Throughout the Enterprise
Ansible
Ansible Introduction
DevOps in the Cloud with Microsoft Azure
Using Groovy with Jenkins
DevOps, A brief introduction to Vagrant & Ansible
Chef Delivery
Puppets
Introduction to chef
Survey: Frozen Yogurt Market in India (2013)
Compliance Automation Workshop
Chef vs Puppet vs Ansible vs SaltStack | Configuration Management Tools Compa...
Chef Fundamentals Training Series Module 6: Roles, Environments, Community Co...
STIG Compliance and Remediation with Ansible
Puppet overview
Infrastructure Automation with Chef
Introduction to Chef
Introduction to puppet
3 Steps to Expand DevOps and Automation Throughout the Enterprise
Ad

Similar to Ansible is the simplest way to automate. MoldCamp, 2015 (20)

PDF
Ansible is the simplest way to automate. SymfonyCafe, 2015
PDF
Ansible - Hands on Training
PDF
Ansible Tutorial.pdf
PPTX
Automating with Ansible
PDF
Automating Complex Setups with Puppet
PDF
A tour of Ansible
PPTX
DevOps for database
PPTX
Go Faster with Ansible (AWS meetup)
PDF
Automating complex infrastructures with Puppet
PDF
Ansible new paradigms for orchestration
PDF
Automated Deployment and Configuration Engines. Ansible
PPTX
Ansible Devops North East - slides
PPTX
Security workflow with ansible
PPTX
Deploying Symfony2 app with Ansible
PPTX
SESSION Ansible how to deploy and push resources
PDF
Getting Started with Ansible
PDF
Devops with Python by Yaniv Cohen DevopShift
PPTX
Ansible presentation
PPTX
ansible-app-platforme-2024-presentation-
PDF
Automação do físico ao NetSecDevOps
Ansible is the simplest way to automate. SymfonyCafe, 2015
Ansible - Hands on Training
Ansible Tutorial.pdf
Automating with Ansible
Automating Complex Setups with Puppet
A tour of Ansible
DevOps for database
Go Faster with Ansible (AWS meetup)
Automating complex infrastructures with Puppet
Ansible new paradigms for orchestration
Automated Deployment and Configuration Engines. Ansible
Ansible Devops North East - slides
Security workflow with ansible
Deploying Symfony2 app with Ansible
SESSION Ansible how to deploy and push resources
Getting Started with Ansible
Devops with Python by Yaniv Cohen DevopShift
Ansible presentation
ansible-app-platforme-2024-presentation-
Automação do físico ao NetSecDevOps

More from Alex S (11)

PDF
Scaling and sharing: Building custom drupal distributions for federated organ...
PPTX
Drupal Training Days 2017 - Drupal 8 basic functions.
PDF
Build your application in seconds and optimize workflow as much as you can us...
PDF
Drupal and diversity of Single sign-on systems
PDF
Getting started with Ansible. Be efficient.
PDF
Building mobile applications with DrupalGap
PDF
Getting Started with DrupalGap
PDF
Drush - use full power - DrupalCamp Donetsk 2014
PDF
DrupalGap. How to create native application for mobile devices based on Drupa...
PDF
Drush. Secrets come out.
PDF
Feeds. использование и создание плагинов. Feeds API
Scaling and sharing: Building custom drupal distributions for federated organ...
Drupal Training Days 2017 - Drupal 8 basic functions.
Build your application in seconds and optimize workflow as much as you can us...
Drupal and diversity of Single sign-on systems
Getting started with Ansible. Be efficient.
Building mobile applications with DrupalGap
Getting Started with DrupalGap
Drush - use full power - DrupalCamp Donetsk 2014
DrupalGap. How to create native application for mobile devices based on Drupa...
Drush. Secrets come out.
Feeds. использование и создание плагинов. Feeds API

Recently uploaded (20)

PDF
Evaluating the Democratization of the Turkish Armed Forces from a Normative P...
PDF
keyrequirementskkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkk
PPTX
Foundation to blockchain - A guide to Blockchain Tech
PPTX
FINAL REVIEW FOR COPD DIANOSIS FOR PULMONARY DISEASE.pptx
PPTX
MCN 401 KTU-2019-PPE KITS-MODULE 2.pptx
PPTX
additive manufacturing of ss316l using mig welding
PPTX
Lesson 3_Tessellation.pptx finite Mathematics
PDF
The CXO Playbook 2025 – Future-Ready Strategies for C-Suite Leaders Cerebrai...
PPT
Project quality management in manufacturing
PPTX
web development for engineering and engineering
PPT
Mechanical Engineering MATERIALS Selection
PDF
Well-logging-methods_new................
PDF
BMEC211 - INTRODUCTION TO MECHATRONICS-1.pdf
PDF
composite construction of structures.pdf
PDF
Operating System & Kernel Study Guide-1 - converted.pdf
PDF
SM_6th-Sem__Cse_Internet-of-Things.pdf IOT
PDF
Structs to JSON How Go Powers REST APIs.pdf
PDF
Digital Logic Computer Design lecture notes
PDF
Model Code of Practice - Construction Work - 21102022 .pdf
PPTX
CYBER-CRIMES AND SECURITY A guide to understanding
Evaluating the Democratization of the Turkish Armed Forces from a Normative P...
keyrequirementskkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkk
Foundation to blockchain - A guide to Blockchain Tech
FINAL REVIEW FOR COPD DIANOSIS FOR PULMONARY DISEASE.pptx
MCN 401 KTU-2019-PPE KITS-MODULE 2.pptx
additive manufacturing of ss316l using mig welding
Lesson 3_Tessellation.pptx finite Mathematics
The CXO Playbook 2025 – Future-Ready Strategies for C-Suite Leaders Cerebrai...
Project quality management in manufacturing
web development for engineering and engineering
Mechanical Engineering MATERIALS Selection
Well-logging-methods_new................
BMEC211 - INTRODUCTION TO MECHATRONICS-1.pdf
composite construction of structures.pdf
Operating System & Kernel Study Guide-1 - converted.pdf
SM_6th-Sem__Cse_Internet-of-Things.pdf IOT
Structs to JSON How Go Powers REST APIs.pdf
Digital Logic Computer Design lecture notes
Model Code of Practice - Construction Work - 21102022 .pdf
CYBER-CRIMES AND SECURITY A guide to understanding

Ansible is the simplest way to automate. MoldCamp, 2015

  • 1. Ansible is the simplest way to automate. Alexander Schedrov aka sanchiz Team Lead, DevOps Engineer, FFW MoldCamp 2015
  • 2. Alexander Schedrov aka sanchiz Team Lead, DevOps Engineer, FFW (ex ProPeople) I love Open Source I'm contributor to Open Source That’s why I’m here Ukraine, Kyiv
  • 3. How it was earlier Developers wrote code SysAdmins deployed code and configure servers
  • 4. until one day… DevOps and Ansible
  • 5. What is Ansible Ansible is a radically simple IT automation engine.
  • 6. Ansible • Clear - Ansible uses a simple syntax (YAML). • Fast - Fast to learn and fast to set up. • Complete - You have everything you need in one complete package. • Efficient - No extra software on your servers. Extensible with modules on any programming language. • Secure - Ansible uses SSH and requires no extra open ports or daemons
  • 8. # Install the PGP key gpg --keyserver keyserver.ubuntu.com --recv-keys 561F9B9CAC40B2F7 gpg --armor --export 561F9B9CAC40B2F7 | apt-key add - # Install https support for apt apt-get install apt-transport-https -y # Add the passenger apt repository echo "deb https://oss-binaries.phusionpassenger.com/apt/passenger raring main" > /etc/apt/sources.list.d/passenger.list chown root: /etc/apt/sources.list.d/passenger.list chmod 600 /etc/apt/sources.list.d/passenger.list # Update the apt cache so we can use the new repo apt-get update # Install nginx apt-get install nginx-full passenger -y # Set up passenger in the nginx configuration sed -i "s/# passenger_root/passenger_root/" /etc/nginx/nginx.conf sed -i "s/# passenger_ruby/passenger_ruby/" /etc/nginx/nginx.conf # Start nginx service nginx restart Shell script
  • 9. --- - hosts: all tasks: - name: Ensure the PGP key is installed apt_key: id=AC40B2F7 state=present url="http://keyserver.ubuntu.com/ pks/lookup?op=get&fingerprint=on&search=0x561F9B9CAC40B2F7" - name: Ensure https support for apt is installed apt: pkg=apt-transport-https state=present - name: Ensure the passenger apt repository is added apt_repository: state=present repo='deb https://oss- binaries.phusionpassenger.com/apt/passenger raring main' - name: Ensure nginx is installed apt: pkg=nginx-full state=present - name: Ensure passenger is installed apt: pkg=passenger state=present update_cache=yes - name: Ensure the nginx configuration file is set copy: src=/app/config/nginx.conf dest=/etc/nginx/nginx.conf - name: Ensure nginx is running service: name=nginx state=started Ansible script
  • 10. Why do we love Ansible • It perfectly fit into our infrastructure • It has a lot of modules and roles • Can easily be executed on multiple servers • Popular system
  • 11. Installation sudo pip install ansible *nix Packages: python-pip and python-devel Windows • Cywgin • PyYAML • Jinja2 • … https://servercheck.in/blog/running-ansible-within-windows
  • 13. 3 main shell commands • ansible-doc [options] [module...] • ansible-playbook playbook.yml [options] • ansible <host-pattern> <command> [options]
  • 14. Additional commands • ansible-galaxy [init|info|install|list|remove] [--help] [options] • ansible-lint playbook.yml [options] • ansible-pull [options] [playbook.yml] • ansible-vault [create|decrypt|edit|encrypt|rekey] [--help] [options] file_name
  • 16. What is playbook Ansible playbook it’s a list of commands or roles that will be executed on remote or local machine.
  • 17. What is Ansible role Ansible role is clean, reusable abstraction that provides certain functionality.
  • 18. --- - hosts: all # Get facts about hosts(OS, user and so on) gather_facts: no remote_user: root vars_prompt: # Variables that need should be entered vars: # List of variables var_files: # List of files with variables roles: # List of roles that should be included pre_tasks: # List of pre-tasks tasks: # List of main tasks post_tasks: # List of post-tasks handlers: # List of handlers
  • 19. Ansible task - name: Install libraries apt: pkg={{ item }} state=installed with_items: - git - apache2 - php5 - php5-mysql Comment/Documentation Module Item Iterate through array
  • 20. Run playbook on remote machine Host Guest 192.168.1.1 192.168.1.2 Playbook on host 192.168.1.2
  • 21. Run playbook on local machine Host 192.168.1.1 Playbook on host 192.168.1.1
  • 22. Inventory # Group name [localhost] # Hosts in group 127.0.0.1 # Group name [mysql_group] # Hosts in group mysqlserver.com 192.168.1.1 # Group vars [mysql_group:vars] ansible_ssh_user=root ansible_ssh_port=2222 /etc/ansible/hosts or ./hosts Requirements: connection by ssh without password.
  • 24. --- - host: lamp_local vars: vhost_core_path: “/var/www/site.dev" domain: "site" tasks: - name: Add Apache virtualhost for development. template: src: "templates/vhost.dev.conf.j2" dest: "/etc/apache2/sites-available/{{ domain }}.dev.conf" owner: root group: root mode: 0644 vhost.dev.conf.j2 <VirtualHost *:80> ServerAdmin webmaster@localhost ServerName {{ domain }}.192.168.60.25.xip.io ServerAlias www.{{ domain }}.192.168.60.25.xip.io DocumentRoot {{ vhost_core_path }} <Directory "{{ vhost_core_path }}"> Options FollowSymLinks Indexes AllowOverride All </Directory> </VirtualHost>
  • 26. Roles --- - hosts: webservers roles: - jenkins - webservers roles/jenkins
  • 27. Use includes --- - hosts: mysql_group sudo: yes vars_files: - solr_vars.yml pre_tasks: - include: pre_tasks.yml tasks: - { include: deploy.yml, user: admin, ssh_keys: [ 'keys/ one.txt', 'keys/two.txt' ] } handlers: - include: handlers/handlers.yml
  • 29. Just run shell scripts through Ansible - name: Deploy system module sudo: yes shell: /usr/bin/deploy -t -v --tags=system Start from small changes
  • 30. Where we use Ansible
  • 31. 1. Configuration management and infrastructure orchestration
  • 36. Our approach • Code Driven Development • Deployments and builds should be automated • We should test each feature before merging into master • Everything that may be automated - should be automated
  • 37. Simple and efficient way ansible-playbook [filename]
  • 38. How do we generate builds • GitHub Pull Requests to inject new features to master branch • Jenkins triggers ansible script within repo • Ansible playbook download database from production • Ansible playbook apply changes to database
  • 40. PUPHPET One day our Vagrantbox is died
  • 42. Provisioning. Vagrant. Vagrant.configure(VAGRANTFILE_API_VERSION) do |config| config.vm.box = "ubuntu/trusty64" config.vm.network :private_network, ip: "192.168.60.77" config.vm.network :forwarded_port, host: 4567, guest: 80 config.vm.provision "ansible" do |ansible| ansible.playbook = "playbook.yml" end end Vagrantfile:
  • 43. Meet the CIBox https://github.com/propeoplemd/cibox Kudos to @podarok,@ygerasimov, @m1r1k and other contributors
  • 44. CIBox uses Ansible for: • Provisioning in CI server (Jenkins) • Provisioning in Vagrantbox • GitHub Pull Request builder
  • 45. Conclusion • Ansible is a promising technology • Easy to start • It solves 95% of our DevOps problems • Ansible is awesome and we love it
  • 46. Thank you! GitHub: https://github.com/Sanchiz Blog: http://sanchiz.net Email: alexander.schedrov@gmail.com Twitter: @alexschedrov Drupal.org: https://www.drupal.org/u/sanchiz