Working With Playbooks
Playbooks are Ansible’s configuration, deployment, and orchestration language. They can describe a policy you want your remote systems to enforce, or a set of steps in a general IT process.
If Ansible modules are the tools in your workshop, playbooks are your instruction manuals, and your inventory of hosts are your raw material.
At a basic level, playbooks can be used to manage configurations of and deployments to remote machines. At a more advanced level, they can sequence multi-tier rollouts involving rolling updates, and can delegate actions to other hosts, interacting with monitoring servers and load balancers along the way.
While there’s a lot of information here, there’s no need to learn everything at once. You can start small and pick up more features over time as you need them.
Playbooks are designed to be human-readable and are developed in a basic text language. There are multiple ways to organize playbooks and the files they include, and we’ll offer up some suggestions on that and making the most out of Ansible.
You should look at Example Playbooks while reading along with the playbook documentation. These illustrate best practices as well as how to put many of the various concepts together.
- Intro to Playbooks
- Creating Reusable Playbooks
-
Variables
- What Makes A Valid Variable Name
- Variables Defined in Inventory
- Variables Defined in a Playbook
- Variables defined from included files and roles
- Using Variables: About Jinja2
- Jinja2 Filters
- Hey Wait, A YAML Gotcha
- Information discovered from systems: Facts
- Turning Off Facts
- Local Facts (Facts.d)
- Ansible version
- Fact Caching
- Registered Variables
- Accessing Complex Variable Data
- Magic Variables, and How To Access Information About Other Hosts
- Variable File Separation
- Passing Variables On The Command Line
- Variable Precedence: Where Should I Put A Variable?
- Variable Scopes
- Variable Examples
- Advanced Syntax
- Templating (Jinja2)
- Conditionals
- Loops
- Blocks
-
Advanced Playbooks Features
- Understanding Privilege Escalation
- Asynchronous Actions and Polling
- Check Mode (“Dry Run”)
- Playbook Debugger
- Delegation, Rolling Updates, and Local Actions
- Setting the Environment (and Working With Proxies)
- Working With Language-Specific Version Managers
- Error Handling In Playbooks
- Advanced Syntax
- Working With Plugins
- Prompts
- Tags
- Using Vault in playbooks
- Start and Step
- Playbook Keywords
- Lookups
- Module defaults
- Strategies
- Best Practices
© 2012–2018 Michael DeHaan
© 2018–2019 Red Hat, Inc.
Licensed under the GNU General Public License version 3.
https://docs.ansible.com/ansible/2.6/user_guide/playbooks.html