Ansible Playbook Template
A git repository template for getting started with a multi-host playbook.

I have created a repository at https://github.com/IanTeda/ansible_playbooks_template to capture my practice of maintaining a multi-host ansible playbook. The repository is a template for getting started with Ansible. It follows the folder and file structure I found the easiest to use
Repository Structure
I have put together this repository with the following Ansible structure:
- ansible.cfg
- Host Inventory
- Group Variables
- Host Variables
Ansible Config
The ansible.cfg file sets the location of the following key files, and thus points Ansible to the correct folders and files:
- inventory = ./inventory
- private_key_file = ~/.ssh/ansible
- vault_password_file = ~/.ansible/vault-pass.txt
Inventory
The host inventory has an entry point of ./inventory/all.yaml, which builds out the children (groups). This file can be .ini or .yaml, I prefer to use .yaml
The inventory file are then broken out into the groups defined in ./inventory/all.yaml
Group Variables
The ./group_vars are broken down into the groups defined in ./inventory/all.yaml. Global variables should be kept variables are defined in./group_vars/all.yaml. Variables of the same name in./group_vars/all.yamlwill be overwritten by variables in groups suck as/group_vars/debain.yaml'
Host Variables
The ./host_vars are broken down into the hosts nominated in inventory group files. Variables of the same name in these files will overwrite variables in ./group_vars.
Private Key File
private_key_file sets the default location of the Ansible user SSH private key that is used to access the remote host.
For some notes on creating an Ansible user check out https://ianteda.com/notes/ansible-user/
Vault Password File
vault_password_file sets the location of the Ansible password for encrypting and decrypting vaults. This stores the password in plain text and should be outside your repository with the appropriate file permissions set. This allows encrypted vaults to be stored in the repository without revealing secrets.
