Skip to content

Latest commit

 

History

History
83 lines (52 loc) · 2.55 KB

README.md

File metadata and controls

83 lines (52 loc) · 2.55 KB
<!--
# README.md for the cluster automation with Ansible
#
# Copyright (c) 2014 PP
#
# author: [email protected]
-->

Getting started

Sources are hosted in the GitHub.

Prerequisities

You will need:

First of all, if you are on Windows, switch to Linux (or Cygwin) before proceeding with this tutorial. It will save you lot of nerves, as Windows is not a devops-friendly system. As for Linux users, it has been tested on Ubuntu Precise. I dont know about OS X, though.

Install Ansible tool

That should take no more than 5 minutes. We will use bleeding edge version from Ansible repository.

$ git clone git://github.com/ansible/ansible.git
$ cd ./ansible
$ source ./hacking/env-setup
$ sudo easy_install pip
$ sudo apt-get install python-dev
$ sudo pip install paramiko PyYAML jinja2 httplib2  

Test that all is good by ansible-pinging own machine

$ echo "127.0.0.1" > ~/ansible_hosts
$ export ANSIBLE_HOSTS=~/ansible_hosts
$ ansible all -m ping --ask-pass

You may want to install Ansible for all users

$ sudo make install

Get the source repo

Assuming that git is already available, clone the entire project

$ git clone [email protected]:piotrpachalko/ansible-cluster.git
$ cd ansible-cluster

Provision the cluster in the cloud

Select your target cloud and credentials

Edit ansible.cfg and edit location of hostfile, if necessary, e.g. if you work with Amazon AWS

hostfile = ./clouds/amazon-aws/ec2.py

Export credentials as variables

$ source ./clouds/amazon-aws/credentials.sh

Look what's already there in the cloud

$ ./clouds/amazon-aws/ec2.py --list

Launch entire cluster

Select playbook containing the cluster definition and see what nodes would be affected and how

$ ansible-playbook cluster-foo.yml --list-hosts
$ ansible-playbook cluster-foo.yml --list-tasks

Now, run the playbook to execute all steps to bring up the cluster

$ ansible-playbook cluster-foo.yml

Stay patient. Ansible will launch necessary instances in the cloud and start configuring them. It takes time on the first run, because Ansible must run all the steps that were not yet executed. Subsequent runs will go faster, unless you destroy the entire cluster or part of it.

After the nodes are up, use ssh to connect to the selected node

ssh {node_name}

Contributing

Follow typical GiHub flow. Fork the repository, make changes and send me a pull request.