Introduction

In the ever-evolving landscape of IT automation, Ansible continues to be a go-to tool for simplifying and streamlining repetitive tasks. While traditionally known for its prowess in system configuration and infrastructure management, Ansible extends its capabilities to even the minutiae of text processing. In this article, we'll explore a practical use case: automating the transformation of text to uppercase using an Ansible playbook.

The Uppercase Ansible Playbook

Below is an Ansible playbook named upper.yml designed to capitalize a given text and print the result on the screen.

``yaml

---

  • name: Uppercase

hosts: all

gather_facts: false

vars:

my_text: "hello world"

tasks:

- name: Print message on the screen

ansible.builtin.debug:

msg: "{{ my_text | upper }}"

`

Breaking down the playbook components:

  • name: Describes the purpose of the playbook.
  • hosts: Specifies the target hosts; in this case, it's set to all for execution on all hosts defined in the inventory.
  • gather_facts: Set to false to skip gathering facts about hosts, ensuring a quicker execution.
  • vars: Defines the my_text variable with the initial value set to "hello world."
  • tasks: Contains a single task to print the uppercase message on the screen.

The Inventory File

Ansible requires an inventory file to specify the hosts where the playbook will run. The inventory file in this example designates the localhost with the connection set to local, indicating that the playbook will be executed on the local machine.

`ini

localhost ansible_connection=local

`

Executing the Playbook

Running the playbook is a straightforward process. The ansible-playbook command, coupled with the -i flag to specify the inventory file, is used:

`bash

$ ansible-playbook -i inventory upper.yml

`

Upon execution, Ansible processes the defined tasks and outputs the result:

`yaml

PLAY [Uppercase] **

TASK [Print message on the screen] **

ok: [localhost] => {

"msg": "HELLO WORLD"

}

PLAY RECAP **

localhost : ok=1 changed=0 unreachable=0 failed=0 skipped=0 rescued=0 ignored=0

`

The output confirms the successful execution of the playbook on the localhost host, resulting in the message "HELLO WORLD" being printed on the screen.

Customizing and Extending

This example illustrates the simplicity of leveraging Ansible for text manipulation tasks. To adapt the playbook for different text or sources, modify the my_text` variable. Additionally, you can expand the playbook's functionality to capitalize text from external files or dynamic inventories.

Conclusion

As Playbooknstrated, Ansible is not only a powerhouse for system configurations but also a versa