Skip to main content

Ansible playbooks layout and examples

Once you have ansible installed and ssh connectivity between the control server and other hosts established you can set up following directly layout with playbooks and execute the examples listed here.

These playbook examples are also available from my Github repository - https://github.com/shahkamran/ansibleplaybooks.

~/.
---+ansible.cfg
---+dev
---+hosts
---+playbooks/
-------------+webserver.yml


-------------+database.yml
-------------+loadbalancer.yml


So where do you start?
You set up your hosts file similar to /etc/hosts but a local one with IP address translation to your systems.

#hosts
192.168.0.1     control
192.168.0.2     app01
192.168.0.3     app02
192.168.0.4     db01
192.168.0.5     lb01

Next you set up your environment in dev file by creating groups of hosts.

#dev
[cc]
control ansible_connection=local
[apps]
app01
app02
[dbs]
db01
[lbs]
lb01

This brings us to the playbooks that you can use as test to execute and build environment.

#loadbalancer.yml
---
  - hosts: lbs
    become: true
    tasks:
        - name: install nginx
          apt: name=nginx state=present update_cache=yes

        - name: ensure nginx started
          service: name=nginx state=started enabled=yes

You can run above using command below;
ansible-playbook loadbalancer.yml

Lets get the web servers set up as well on app servers.

#webserver.yml
---
  - hosts: apps
    become: true
    tasks:
        - name: install web server components
          apt: name={{item}} state=present update_cache=yes
          with_items:
                - apache2
                - libapache2-mod-wsgi
                - python-pip
                - python-virtualenv

        - name: ensure apache2 started
          service: name=apache2 state=started enabled=yes

        - name: ensure mod_wsgi enabled
          apache2_module: state=present name=wsgi
          notify: Restart Apache2
    handlers:
        - name: Restart Apache2
          service: name=apache2 state=restarted

Run following;
ansible-playbook webserver.yml

And the database goes here.

#database.yml
---
  - hosts: dbs
    become: true
    tasks:
        - name: install mysql-server
          apt: name=mysql-server state=present update_cache=yes

        - name: ensure mysql-server started
          service: name=mysql state=started enabled=yes

Get it up and running by;
ansible-playbook database.yml

That is all your environment set up now. If you want you can play with the examples above and enhance your usage, for example you can create a playbook to restart the whole application stack using below playbook.

#stack_restart.yml
---
# Bring stack down
- hosts: lbs
  become: true
  tasks:
  - service: name=nginx state=stopped

- hosts: apps
  become: true
  tasks:
  - service: name=apache2 state=stopped

# Restart mysql
- hosts: dbs
  become: true
  tasks:
  - service: name=mysql state=restarted

# Bring stack up
- hosts: apps
  become: true
  tasks:
  - service: name=apache2 state=started

- hosts: lbs
  become: true
  tasks:
  - service: name=nginx state=started

You restart your stack using command below;
ansible-playbook stack_restart.yml

Hope you find these useful.

Popular posts from this blog

Useful website performance and load testing tools

http://tsung.erlang-projects.org/ http://httpd.apache.org/docs/2.0/programs/ab.html http://phantomjs.org/ https://developers.google.com/speed/pagespeed/ http://servermonitoringhq.com/blog/how_to_quickly_stress_test_a_web_server https://code.google.com/p/httperf/ http://loadimpact.com/ http://www.paessler.com/webstress http://loaduiweb.org/ http://en.wikipedia.org/wiki/Web_server_benchmarking http://en.wikipedia.org/wiki/Load_testing http://www.loadui.org/ http://www.loadtestingtool.com/index.shtml http://www.appdynamics.com/blog/devops/load-testing-tools-explained-the-server-side/

VMWare ESXi 6.5 HP Custom Image Upgrade to v6.5U3

I had been escaping the Unhandled Exception error every time I log into my ESXi standalone server running v6.5 on N54L and can't be upgraded to v6.7 due to process compatibility. I have finally found the HP Custom image updated to v6.5U3 which appeared to have the fix built into it. It was quite straightforward update using the l latest 6.5 HP image so as habit I am making notes here for myself and everyone else who may find it useful. First of all I downloaded HP Custom v6.5U3 image  by selecting Offline Bundle. I then placed it in my datastore e.g. ds001. Once copied I ran following command line after I was connected to ESXi using ssh. # esxcli software vib update -d /vmfs/volumes/ds001/VMware-ESXi-6.5.0-Update3-14990892-HPE-preGen9-650.U3.9.6.10.1-Dec2019-depot.zip This command took few seconds or may be minutes but confirmed that updates have been installed and will take effect after reboot. So I rebooted the host and it worked like magic. # reboot I did not place host in main...

TrueCrypt on macOS X Mojave 10.14

If you have updated your macOS recently to Mojave otherwise known as verison 10.14 you may not be able to install the last version of Truecrypt in order to access your old volumes encrypted with Truecrypt software. This article will guide you to get this working on your MacOS v10.14 (Mjoave) . Download the package from  https://truecrypt.ch/downloads/  or  https://www.truecrypt71a.com/downloads/ . Find downloaded package using Finder in your HDD/Users/username/Downloads folder and will look like  TrueCrypt 7.1a Mac OS X.dmg . Open file location in Finder and open or double click on  TrueCrypt 7.1a Mac OS X.dmg . This will mount Truecrypt 7.1a and will have Truecrypt 7.1a.mpkg in it. Drag the package T rueCrypt 7.1a.mpkg and drop in your Downloads folder. From Locations in Finder you can eject your TrueCrypt mount. Now go to your Downloads location, find the file  TrueCrypt 7.1a.mpkg , right click and select Show Package Contents . Find the ...