Monday, 8 January 2018

Ansible ( a small working example )

This is brief tutorial on how to install wordpress on your remote Ubuntu server using Ansible.
Well before starting work, I will assume you have already installed Ansible on your local machine and have a password less entry to the remote server using SSH keys.
Well then on with work:

# cd /home
# mkdir wordpress-full-install && cd wordpress-full-install
# touch site.yml
# touch hosts
# mkdir roles && cd roles

Staying in the same folder initialize four different roles using Ansible galaxy:

# ansible-galaxy init common
# ansible-galaxy init php
# ansible-galaxy init mysql
# ansible-galaxy init wordpress
# nano ~/wordpress-full-install/hosts (This will tell Ansible on which server to deploy the role)

[wpserver]
wp.remoteserver.com

# nano ~/wordpress-full-install/site.yml (This is where we make our roles are executed sequentially when the role is executed)

- hosts: wpserver

  roles:
    - common
    - php
    - mysql
    - wordpress


# nano roles/common/tasks/main.yml ( First we set out a complete lamp stack )

---
- name: Update apt cache
  apt: update_cache=yes cache_valid_time=3600
  sudo: yes

- name: Install required software
  apt: name={{ item }} state=present
  sudo: yes
  with_items:
    - apache2
    - mysql-server
    - php5-mysql
    - php5
    - libapache2-mod-php5
    - php5-mcrypt
    - python-mysqldb


# nano roles/php/tasks/main.yml ( Here we install the required php dependencies )

---
- name: Install php extensions
  apt: name={{ item }} state=present
  sudo: yes
  with_items:
    - php5-gd
    - libssh2-php


# nano roles/mysql/defaults/main.yml ( Sets up some default variable for DB )

---
wp_mysql_db: wordpress
wp_mysql_user: wordpress
wp_mysql_password: mysecretpassword


# nano roles/mysql/tasks/main.yml ( Installs and configures the DB on the targeted server )

---
- name: Create mysql database
  mysql_db: name={{ wp_mysql_db }} state=present

- name: Create mysql user
  mysql_user:
    name={{ wp_mysql_user }}
    password={{ wp_mysql_password }}
    priv=*.*:ALL


# nano roles/wordpress/tasks/main.yml ( This is where the entire install takes place for wordpress and different configurations are made to adjust to lamp stack )

---
- name: Download WordPress
  get_url:
    url=https://wordpress.org/latest.tar.gz
    dest=/tmp/wordpress.tar.gz
    validate_certs=no
  sudo: yes

- name: Extract WordPress
  unarchive:
    src=/tmp/wordpress.tar.gz dest=/var/www/
    copy=no
  sudo: yes

- name: Update default Apache site
  sudo: yes
  lineinfile:
    dest=/etc/apache2/sites-enabled/000-default.conf
    regexp="(.)+DocumentRoot /var/www/html"
    line="DocumentRoot /var/www/wordpress"
  notify:
    - restart apache

- name: Copy sample config file
  command: mv /var/www/wordpress/wp-config-sample.php /var/www/wordpress/wp-config.php creates=/var/www/wordpress/wp-config.php
  sudo: yes

- name: Update WordPress config file
  lineinfile:
    dest=/var/www/wordpress/wp-config.php
    regexp="{{ item.regexp }}"
    line="{{ item.line }}"
  with_items:
    - {'regexp': "define\\('DB_NAME', '(.)+'\\);", 'line': "define('DB_NAME', '{{wp_mysql_db}}');"}
    - {'regexp': "define\\('DB_USER', '(.)+'\\);", 'line': "define('DB_USER', '{{wp_mysql_user}}');"}
    - {'regexp': "define\\('DB_PASSWORD', '(.)+'\\);", 'line': "define('DB_PASSWORD', '{{wp_mysql_password}}');"}
  sudo: yes


# nano roles/wordpress/handlers/main.yml ( This is the action listener, when apache configuration is changed while installing wordpress a service restart is required for apache – This Handler is just a task but only executes when the previous task has been executed successfully )

---
- name: restart apache
  service: name=apache2 state=restarted
  sudo: yes


# cd /home/wordpress-full-install
# ansible-playbook -i hosts site.yml

That’s it! With just the above command your entire wordpress will be deployed onto the remote server.
If needed to be installed on different servers just change the entries in the hosts file. Or just give the –I path to the specific file which contains the entries to the different server list.