4.7 KiB
Day 27: 90DaysofDevOps
From Automated to Automatic - Event-Driven Infrastructure Management with Ansible
Daniel Bodky
Overview
A universal truth and recurring theme in the DevOps world is automation. From providing infrastructure to testing code to deploying to production, many parts of the DevOps lifecycle get automated already. One popular technology for managing infrastructure and configuration in an automated way is Ansible, but are we fully utilizing its capabilities yet?
This presentation will give a broad overview of Ansible and its architecture and use-cases, before exploring a relatively new feature, Event-driven Ansible (EDA). Analzying applications of event-driven Ansible, participants will see that automated management is nice, but automatic management is awesome, not just regarding DevOps principles, but also in terms of reaction times, the human tendency for minor mistakes, and toil for operators.
Participants will get first-hand insights into Ansible, its strengths, weaknesses, and the potential of event-driven automation within the DevOps world.
Note
The below content is a copy of the lab repository's README for convenience.
Event-Driven Ansible Lab
This is a lab designed to demonstrate Ansible and how Event-Driven Ansible (EDA) builds on top of its capabilities.
The setup is done with Ansible, too. It will install Ansible, EDA, Prometheus, and Alertmanager on a VM to demonstrate some of the capabilities of EDA.
Prerequisites
To follow along with this lab in its entirety, you will need three VMs:
Note
If you want to skip Ansible basics and go straight to EDA, you'll need just the
eda-controller.example.com
VM and can skip the others.
VM name | OS |
---|---|
eda-controller.example.com | CentOS/Rocky 8.9 |
company.example.com | CentOS/Rocky 8.9 |
webshop.example.com | Ubuntu 22.04 |
You'll need to be able to SSH to each of these VMs as root using SSH keys.
Lab Setup
Clone the repository and create a Python virtual environment
git clone https://github.com/mocdaniel/lab-event-driven-ansible.git
cd lab-event-driven-ansible
python3 -m venv .venv
source .venv/bin/activate
Install Ansible and other dependencies
pip install -r requirements.txt
Create the inventory file
---
# hosts.yml
webservers:
hosts:
webshop.example.com:
ansible_host: <ip-address>
webserver: apache2
company.example.com:
ansible_host: <ip-address>
webserver: httpd
eda_controller:
hosts:
eda-controller.example.com:
ansible_host: <ip-address>
Install Needed Roles and Collections
ansible-galaxy install -r requirements.yml
Run the Setup Playbook
After you created the inventory file and filled in the IP addresses, you can run the setup playbook:
ansible-playbook playbooks/setup.yml
Caution
Due to a known bug with Python on MacOS, you need to run
export NO_PROXY="*"
on MacOS before running the playbook
Demos
Lab 1: Ansible Basics
Ansible from the CLI via ansible
Ansible from the CLI via ansible
The first example installs a webserver on all hosts in the webservers
group. The installed webserver is defined as a host variable in the inventory file hosts.yml
(see above).
ansible \
webservers \
-m package \
-a 'name="{{ webserver }}"' \
--one-line
Afterwards, we can start the webserver on all hosts in the webservers
group.
ansible \
webservers \
-m service \
-a 'name="{{ webserver }}" state=started' \
--one-line
Go on and check if the web servers are running on the respective hosts.
Tip
Ansible is idempotent - try running the commands again and see how the output differs.
Ansible from the CLI via ansible-playbook
Ansible from the CLI via ansible-playbook
The second example utilizes the following playbook to gather and display information for all hosts in the webservers
group, utilizing the example role from the lab repository.
---
- name: Example role
hosts: webservers
gather_facts: false
vars:
greeting: "Hello World!"
pre_tasks:
- name: Say Hello
ansible.builtin.debug:
msg: "{{ greeting }}"
roles:
- role: example
post_tasks:
- name: Say goodbye
ansible.builtin.debug:
msg: Goodbye!
ansible-playbook \
playbooks/example.yml