Ansible
- Summary
-
Discussion
- What are some typical use cases of Ansible?
- In Ansible, what do mean by "agentless" architecture?
- Could you describe some essentials Ansible terms?
- What's the Ansible architecture?
- Could you share some best practices when using Ansible?
- Could you point to useful resources to get started with Ansible?
- Milestones
- Sample Code
- References
- Further Reading
- Article Stats
- Cite As
When software is delivered as a service, it's important that the server and the application running on it are initialized or configured correctly. Sometimes server modules or the application itself will need to be patched or upgraded. This task is more difficult when the service resides in the cloud and is running on multiple servers. What we need is a tool to automate these tasks. This is where Ansible is useful.
Ansible is well known as a configuration tool that can help us put a remote machine into a desired state. But Ansible can do more: deploy applications, orchestrate multiple tasks across multiple machines, run ad-hoc commands. In short, Ansible is a tool that enables Infrastructure-as-Code (IaC).
Discussion
-
What are some typical use cases of Ansible? The main uses of Ansible are the following:
- Provisioning: Provision bare-metal servers, VMs, cloud instances, and more.
- Configuration Management: Centralize configuration and push the same to all machines. This means a consistent environment for your services regardless of the machine.
- App Deployment: Manage your app's lifecycle easily, from development to production.
- Continuous Delivery: Create CI/CD pipelines without additional complexity.
- Security & Compliance: Scan and remediate site-wide security policies.
- Orchestration: Orchestrate how multiple configurations interact; manage the environment as a whole and not in silos.
Consider an example of orchestration. A three-tier web app will have app servers, database servers, content servers, load balancers and a monitoring system. Ansible can do a complex cluster-wide rolling update without any downtime. In fact, Ansible enables immutable infrastructure, meaning that we can replace servers without service disruption.
It's interesting to note that Ansible configuration can be seen as a type of documentation and a solution for disaster recovery.
-
In Ansible, what do mean by "agentless" architecture? To configure a number of host machines, one approach is to install custom programs, called agents, on each of these machines. The system will also have a server or control node that contains the current configuration. Each agent will periodically poll the server to obtain the configuration. The server and agent communicate using a common pre-defined protocol and port. This is otherwise called the pull approach.
In Ansible, there are no agents. It uses the push approach, whereby the server pushes configuration or commands to the hosts. Hosts are often diverse. Installing agent programs on different OS/platform is a hassle. In Ansible, SSH is used by the server to talk to a host. OpenSSH is widely deployed. It's open source and lightweight.
What if an agent crashes? What if server and agents have mismatching versions? Some agents have reportedly used 400MB of memory. Ansible's agentless architecture avoids all these issues. We can start managing the hosts with zero bootstrapping.
-
Could you describe some essentials Ansible terms? From the complete Ansible Glossary, we describe a few essential terms:
- Node: Can either be a Control Node or a Managed Node. Ansible is installed on control nodes but not on managed nodes. Managed nodes are also called hosts.
- Inventory: A list of managed nodes, specified by an inventory file or hostfile. Hosts can be organized into groups for easier scaling.
- Task: A unit of execution in Ansible. Each task has an associated command and does a single operation unless it has a loop.
- Playbook: An ordered list of tasks. These are designed to be easy to read, write, share and understand. Playbooks can use variables.
- Module: Reusable code that Ansible executes and can be invoked by a task. Ansible comes with dozens of out-of-the-box and ready-to-use modules. Modules are typically organized by their purpose: crypto, database, identity, messaging, network, storage, etc.
- Role: Makes playbooks modular and reusable. These are units of organization in Ansible. A role can apply variables, tasks or handlers to hosts or groups.
-
What's the Ansible architecture? Ansible executes on a control node and connects to hosts using SSH by default. Control node can be Linux, MacOS, or even any machine that has Python 2.7 or 3.5+ installed. Nodes need to have either SSH or PowerShell (Windows); and Python 2.6+ or 3.5+ installed. File transfer is done using
sftp
orscp
.Hosts to be managed are listed in files called inventory. Modules offer reusable execution code. Playbooks contain step-by-step instructions.
Configuration and playbooks are stored as YAML files in a well-defined directory layout. YAML is easier to learn than bash scripting. Ansible Tower, the enterprise version of Ansible, allows configuration to be stored in configuration management databases (CMDB), using PostgreSQL or MongoDB.
If Ansible modules are the tools in your workshop, playbooks are your instruction manuals, and your inventory of hosts are your raw material.
-
Could you share some best practices when using Ansible? Keep it simple. Think declaratively. Don't write code in playbooks. Since modules abstract away complexity, always check if there's a module to accomplish what you want. Avoid using run commands (
command
,shell
,raw
,script
), since error and state handling are difficult. Instead, write your own modules.Don't ignore errors with
ignore_errors: yes
since you'll miss unexpected errors as well. Instead usefailed_when
and other alternatives. Along with roles, useimport*
andinclude*
statements to logically chunk and reuse Ansible content.In the interest of readability, use descriptive names for both plays and tasks. Variable names can collide. Use prefixes to avoid collision and also improve readability, such as,
apache_port
andtomcat_port
rather than justport
.YAML's native syntax for name-value pairs is
name: value
. Use this for readability in preference of Ansible's shorthandname=value
. The YAML syntax is easier to read and highlighted by editors and IDEs.When using the debug module, use the
verbosity
parameter to suppress debug messages in production.Organize your playbooks based on roles. Have separate inventory for staging and production. Define groups based on roles and geography.
Ansible-Lint and Playbook Best Practices guides can help.
-
Could you point to useful resources to get started with Ansible? From Ansible's official site, read an overview of Ansible. Learn about setting up SSH keys and running your first commands in the Getting Start guide. There are also a number of useful whitepapers on Ansible.
To be part of or contribute, read the Ansible Community Guide.
Ansible Galaxy is a hub for downloading useful roles. Official documentation lists all Ansible modules.
Milestones
2012
2013
2014
2017
Ansible 2.4 is released. For hosts, support for Python 2.4 and 2.5 are dropped. Old include
directives are replaced with import
(static) and include
(dynamic). Keyword order
can be used to specify the order in which hosts are processed. Inventory is revamped. The release is updated in July 2018 as v2.4.7.
2018
Ansible 2.5 is released. It's recommended to use loop
keyword instead of with_*
style loops. The new syntax is better with filters instead of using complex query
or lookup
. Two top-level persistent connection types are introduced, network_cli
and netconf
. Where possible, prefer these over local
connections.
Sample Code
References
- Ansible. 2017. "Ansible in Depth." Whitepaper, Ansible, Red Hat. Accessed 2019-06-03.
- Ansible. 2018. "The Benefits of Agentless Architecture." Whitepaper, Ansible, Red Hat. Accessed 2019-06-03.
- Ansible. 2019a. "Use Cases." Ansible, Red Hat. Accessed 2019-06-04.
- Ansible. 2019b. "Ansible - Our Story." Ansible, Red Hat. Accessed 2019-06-04.
- Ansible Docs. 2019a. "Glossary." Ansible 2.8, May 28. Accessed 2019-06-04.
- Ansible Docs. 2019b. "Best Practices." Ansible 2.8, May 28. Accessed 2019-06-04.
- Ansible Docs. 2019c. "Working With Playbooks." Ansible 2.8, May 28. Accessed 2019-06-04.
- Ansible Docs. 2019d. "Getting Started." Ansible 2.8, May 28. Accessed 2019-06-04.
- Ansible Docs. 2019e. "Basic Concepts." Ansible 2.8, May 28. Accessed 2019-06-04.
- Ansible Docs. 2019f. "Module Index." Ansible 2.8, May 28. Accessed 2019-06-04.
- Ansible Docs. 2019g. "Installation Guide." Ansible 2.8, May 28. Accessed 2019-06-04.
- Ansible Docs. 2019h. "Windows Support." Ansible 2.8, May 28. Accessed 2019-06-04.
- Ansible Docs. 2019i. "Ansible 2.5 Porting Guide." Ansible 2.8, May 28. Accessed 2019-06-04.
- Ansible GitHub. 2018. "Ansible Changes By Release." Commit 737d8a0, September 05. Accessed 2019-06-05.
- Ansible GitHub. 2019a. "ansible/ansible." Commit 87422ea, June 03. Accessed 2019-06-03.
- Ansible GitHub. 2019b. "Ansible 2.5 "Kashmir" Release Notes." Commit 4ad6924, February 21. Accessed 2019-06-05.
- Appnel, Timothy. 2016. "Ansible Best Practices: The Essentials." The Inside Playbook Blog, Red Hat Ansible, August 31. Accessed 2019-06-03.
- Berder, Ronan. 2015. "Getting Started With Ansible in 5 Minutes." Wiredcraft, March 30. Accessed 2019-06-04.
- DeHaan, Michael. 2012. "Ansible - A Simple Model-Driven Configuration Management and Command Execution Framework." High Scalability, April 18. Accessed 2019-06-03.
- DeHaan, Michael. 2013. "The Origins of Ansible." Blog, Ansible, December 08. Accessed 2019-06-04.
- Dober, Kat. 2018. "New to Ansible? Check Out Our Best Practices Guide." New Relic, May 09. Accessed 2019-06-03.
- Goossens, Niels. 2017. "A (very) Short Comparison of Ansible, Chef, Puppet and SaltStack." LinkedIn Pulse, September 08. Accessed 2019-06-03.
- Holmberg, Frederik. 2016. "Measuring wireless performance using Ansible, Elastic Stack and MikroTik." March 30. Accessed 2019-06-04.
- Jamison, Creston. 2015. "Ansible Introduction." Ruby Tree Software, Inc., via YouTube, February 24. Accessed 2019-06-03.
- Modine, Austin. 2008. "Cobbler pieces together mass Red Hat Linux installations." The Register, June 19. Accessed 2019-06-03.
- Raun, Corban. 2015. "Lessons from using Ansible exclusively for 2 years." Blog, Server Density, March 24. Accessed 2019-06-04.
- Red Hat. 2019. "Ansible Quick Start Video." Accessed 2019-06-03.
- Sesto, Vince. 2019. "2019 — Ansible Takes Over As Top Cloud Configuration Management Tool." SplunkUDA, via Medium, March 07. Accessed 2019-06-06.
- Thomas, Nyambati. 2017. "Getting started with Ansible." Scotch, May 10. Accessed 2019-06-04.
Further Reading
- Ansible Docs. 2019a. "Glossary." Ansible 2.8, May 28. Accessed 2019-06-04.
- Thomas, Nyambati. 2017. "Getting started with Ansible." Scotch, May 10. Accessed 2019-06-04.
- DeHaan, Michael. 2013. "The Origins of Ansible." Blog, Ansible, December 08. Accessed 2019-06-04.
- Shi Ching, Tien. 2018. "Ansible Basics in 5 Minutes." Faun, via Medium, August 04. Accessed 2019-06-04.
- Chauveau, Florent. 2018. "CI/CD: Using GitLab + Docker + Ansible." Blog, Callr, September 20. Accessed 2019-06-03.
Article Stats
Cite As
See Also
- Continuous Delivery
- DevOps
- Deployment Workflow
- Canary Deployments
- Robotic Process Automation
- Cloud Orchestration