136 lines
7.1 KiB
ReStructuredText
136 lines
7.1 KiB
ReStructuredText
Getting Started in EC2
|
|
======================
|
|
|
|
.. image:: http://ansible.cc/docs/_static/ansible_fest_2013.png
|
|
:alt: ansiblefest 2013
|
|
:target: http://ansibleworks.com/fest
|
|
|
|
|
|
.. contents::
|
|
:depth: 2
|
|
:backlinks: top
|
|
|
|
Introduction
|
|
````````````
|
|
|
|
Ansible contains a number of core modules for interacting with Amazon Web Services (AWS) and other API compatible private clouds, such as Eucalyptus. This page illustrates some use cases for provisioning and managing hosts EC2 resources.
|
|
|
|
Requirements for the AWS modules are minimal. All of the modules require and are tested against boto 2.5 or higher. You'll need this Python module installed on the execution host. `Use EPEL <http://fedoraproject.org/wiki/EPEL>``_ and install as follows under RHEL/CentOS:
|
|
|
|
.. code-block:: bash
|
|
|
|
$ yum install python-boto
|
|
|
|
Provisioning
|
|
````````````
|
|
|
|
The ec2 module provides the ability to provision instance(s) within EC2. You may wish to use Ansible in task-execution mode or create a simple provisioning playbook. Typically the provisioning task will be performed against your Ansible master server as a local_action.
|
|
|
|
.. note::
|
|
|
|
Authentication with the AWS-related modules is handled by either
|
|
specifying your access and secret key as ENV variables or passing
|
|
them as module arguments.
|
|
|
|
.. note::
|
|
|
|
To talk to specific endpoints, the environmental variable EC2_URL
|
|
can be set. This is useful if using a private cloud like Eucalyptus,
|
|
exporting the variable as EC2_URL=https://myhost:8773/services/Eucalyptus
|
|
|
|
Provisioning a number of instances in task execution mode:
|
|
|
|
.. code-block:: bash
|
|
|
|
# ansible localhost -m ec2 -a "image=ami-6e649707 instance_type=m1.large keypair=mykey group=webservers wait=yes"
|
|
|
|
In a play, this might look like (assuming the parameters are held as vars)::
|
|
|
|
tasks:
|
|
- name: Provision a set of instances
|
|
local_action: ec2 keypair=$mykeypair group=$security_group instance_type=$instance_type image=$image wait=true count=$number
|
|
register: ec2
|
|
|
|
By registering the return its then possible to dynamically create a host group consisting of these new instances. This facilitates performing configuration actions on the hosts in a subsequent play::
|
|
|
|
tasks:
|
|
- name: Add all instance public IPs to host group
|
|
local_action: add_host hostname={{ item.public_ip }} groupname=ec2hosts
|
|
with_items: '{{ ec2.instances }}'
|
|
|
|
With the host group now created, the second play in your provision playbook might now have some configuration steps::
|
|
|
|
- name: Configuration play
|
|
hosts: ec2hosts
|
|
user: ec2-user
|
|
gather_facts: true
|
|
|
|
tasks:
|
|
- name: Check NTP service
|
|
action: service name=ntpd state=started
|
|
|
|
The method above ties the configuration of a host with the provisioning step. This isn't always ideal and leads us onto the next section.
|
|
|
|
Advanced Usage
|
|
``````````````
|
|
|
|
Host Inventory
|
|
++++++++++++++
|
|
|
|
How can provisioning be decoupled from typical management of the hosts?
|
|
|
|
For larger environments and those looking toward production use, you may wish to use provisioning playbooks utilizing the various AWS-related modules, or use your own favourite tool (perhaps basic CloudFormation templates) to create resources in EC2. Once these are created and you wish to configure them, the EC2 API can be used to return system grouping with the help of the EC2 inventory script. This script can be used to group resources by their security group or tags. Tagging is highly recommended in EC2 and can provide an easy way to sort between host groups and roles. The inventory script is documented `here <http://ansible.cc/docs/api.html#external-inventory-scripts>`_.
|
|
|
|
You may wish to schedule a regular refresh of the inventory cache to accomodate for frequent changes in resources:
|
|
|
|
.. code-block:: bash
|
|
|
|
# ./ec2.py --refresh-cache
|
|
|
|
Put this into a crontab as appropriate to make calls from your Ansible master server to the EC2 API endpoints and gather host information. The aim is to keep the view of hosts as up-to-date as possible, so schedule accordingly. Playbook calls could then also be scheduled to act on the refreshed hosts inventory after each refresh. This approach means that machine images can remain "raw", containing no payload and OS-only. Configuration of the workload is handled entirely by Ansible.
|
|
|
|
Pull Configuration
|
|
++++++++++++++++++
|
|
|
|
For some the delay between refreshing host information and acting on that host information (i.e. running Ansible tasks against the hosts) may be too long. This may be the case in such scenarios where EC2 AutoScaling is being used to scalethe number of instances as a result of a particular event. Such an event may require that hosts come online and are configured as soon as possible (even a 1 minute delay may be undesirable). Its possible to pre-bake machine images which contain the necessary ansible-pull script and components to pull and run a playbook via git. The machine images could be configured to run ansible-pull upon boot as part of the bootstrapping procedure.
|
|
|
|
More information on pull-mode playbooks can be found `here <http://ansible.cc/docs/playbooks2.html#pull-mode-playbooks>`_.
|
|
|
|
Use Cases
|
|
`````````
|
|
|
|
This section covers some usage examples built around a specific use case.
|
|
|
|
Example 1
|
|
+++++++++
|
|
|
|
Example 1: I'm using CloudFormation to deploy a specific infrastructure stack. I'd like to manage configuration of the instances with Ansible.
|
|
|
|
Provision instances with your tool of choice and consider using the inventory plugin to group hosts based on particular tags or security group. Consider tagging instances you wish to managed with Ansible with a suitably unique key=value tag.
|
|
|
|
Example 2
|
|
+++++++++
|
|
|
|
Example 2: I'm using AutoScaling to dynamically scale up and scale down the number of instances. This means the number of hosts is constantly fluctuatingi but I'm letting EC2 automatically handle the provisioning of these instances. I don't want to fully bake a machine image, I'd like to use Ansible to configure the hosts.
|
|
|
|
There are two approaches to this use case. The first is to use the inventory plugin to regularly refresh host information and then target hosts based on the latest inventory data. The second is to use ansible-pull triggered by a user-data script (specified in the launch configuration) which would then mean that each instance would fetch Ansible and the latest playbook from a git repository and run locally to configure itself.
|
|
|
|
Example 3
|
|
+++++++++
|
|
|
|
Example 3: I don't want to use Ansible to manage my instances but I'd like to consider using Ansible to build my fully-baked machine images.
|
|
|
|
There's nothing to stop you doing this. If you like working with Ansible's playbook format then writing a playbook to create an image; create an image file with dd, give it a filesystem and then install packages and finally chroot into it for further configuration.
|
|
|
|
|
|
.. seealso::
|
|
|
|
:doc:`examples`
|
|
Examples of basic commands
|
|
:doc:`playbooks`
|
|
Learning ansible's configuration management language
|
|
`Mailing List <http://groups.google.com/group/ansible-project>`_
|
|
Questions? Help? Ideas? Stop by the list on Google Groups
|
|
`irc.freenode.net <http://irc.freenode.net>`_
|
|
#ansible IRC chat channel
|
|
|