ansible-role-apache/lamp_haproxy
2014-07-01 13:18:32 -04:00
..
group_vars http in git is depricated. 2013-11-20 21:13:07 -06:00
roles Move installing SE Linux python bindings to common role 2014-07-01 13:18:32 -04:00
hosts fix up hosts inventory example for lamp_haproxy (fix #15) 2013-06-29 13:10:04 -07:00
LICENSE.md add CC licenses to AnsibleWorks-contributed examples 2013-10-03 17:44:59 -07:00
README.md Minor improvements 2013-04-19 13:35:24 -07:00
rolling_update.yml fixed /n to [] 2013-10-11 11:33:59 -05:00
site.yml Simplify site.yml and allow parallelization of 'common' role tasks, and update to new pre_task/post_task syntax for rolling update. 2013-04-25 20:03:03 -07:00

LAMP Stack + HAProxy: Example Playbooks

  • Requires Ansible 1.2
  • Expects CentOS/RHEL 6 hosts

This example is an extension of the simple LAMP deployment. Here we'll install and configure a web server with an HAProxy load balancer in front, and deploy an application to the web servers. This set of playbooks also have the capability to dynamically add and remove web server nodes from the deployment. It also includes examples to do a rolling update of a stack without affecting the service.

You can also optionally configure a Nagios monitoring node.

Initial Site Setup

First we configure the entire stack by listing our hosts in the 'hosts' inventory file, grouped by their purpose:

	[webservers]
	webserver1
	webserver2
	
	[dbservers]
	dbserver
	
	[lbservers]
	lbserver
	
	[monitoring]
	nagios

After which we execute the following command to deploy the site:

	ansible-playbook -i hosts site.yml

The deployment can be verified by accessing the IP address of your load balancer host in a web browser: http://:8888. Reloading the page should have you hit different webservers.

Removing and Adding a Node

Removal and addition of nodes to the cluster is as simple as editing the hosts inventory and re-running:

    ansible-playbook -i hosts site.yml

Rolling Update

Rolling updates are the preferred way to update the web server software or deployed application, since the load balancer can be dynamically configured to take the hosts to be updated out of the pool. This will keep the service running on other servers so that the users are not interrupted.

In this example the hosts are updated in serial fashion, which means that only one server will be updated at one time. If you have a lot of web server hosts, this behaviour can be changed by setting the 'serial' keyword in webservers.yml file.

Once the code has been updated in the source repository for your application which can be defined in the group_vars/all file, execute the following command:

 ansible-playbook -i hosts rolling_update.yml

You can optionally pass: -e webapp_version=xxx to the rolling_update playbook to specify a specific version of the example webapp to deploy.