Ansible Server Inventory: Manage Server Inventory with Ansible. In this post, we introduce Ansible inventory, types of inventory then shows you how to create a custom inventory to organize servers by group and name.
An inventory is an indispensable part of managing systems with Ansible, which is an open source automation tool. Ansible Inventory is a file that has data about the hosts and bunches of hosts that it impacts the automation process.
In the case of Ansible, an inventory is an organized and cleanly formatted file that offers necessary data about the managed hosts. The main objective of the inventory is to clarify the target systems so that Ansible performs tasks and playbooks on them.
A well structured inventory comprises vital information such as hostnames, IP addresses, credentials, host groups, and SSH. The inventory works as a roadmap for Ansible to decide which systems to communicate with and how to manage the automation process.
An Ansible standard inventory file is written in INI or plain text format, even though YAML is getting more popular day by day for its readability and flexibility. Now how to store an inventory file? Well, it is stored locally on the control node or remotely hosted on a version control system, for example, Git, which enables easy access and is shared between teammates.
The common and static inventory contains groups and a confirmed list of hosts, which are defined inside a static file. The process of creating is very simple, and it is very efficient for small scale environments that have a small number of hosts.
But, in ever changing environments, the hosts change incessantly, so managing a static inventory is a very difficult task with a probability of mistakes.
2. Dynamic Inventory
The Dynamic inventory offers a fix for dynamic environments; some examples are cloud based infrastructures, where hosts are equipped and withdraw dynamically.
Instead of using a static file, dynamic inventory scripts create the inventory without interruption while running the program. It is done by querying outer sources like the configuration management database (CMDB) and cloud providers’ APIs.
A composite inventory joins both static and dynamic inventories; it allows users to gain the benefits of both dynamic and static inventories. This method is used, especially when partial hosts are relatively static and others are constantly changing.
It allows businesses to retain important parts, for example, network devices and physical servers, that are defined in a static inventory during the process of auto scaling, and cloud based instances are regulated dynamically.
At the time of performing Ansible reads the inventory file distinct with the usage of the -i or –inventory-file option. Ansible looks for a location that is defaulted to, for example, /etc/ansible/hosts, in the absence of an inventory file. After the loading of inventory, Ansible categorizes hosts into sets based on the distinct classes in the inventory file.
Groups are indicated by square brackets, and single hosts are enlisted below the group name to which they belong. Ansible aims single hosts or complete groups for operations, which makes it super easy to operate tasks on various systems at a time. Hosts relate to many groups, allowing logical classifications and the capability to do selected measures depending on these categories.
Ansible Server Inventory: Manage Your Server Inventory with Ansible
In this section, we show you how to create a custom inventory file and execute commands using this inventory on a specific host and group.
Create a Custom Inventory File
By default, Ansible default inventory file is located at /etc/ansible/hosts. However, it is always a good idea to create a custom inventory file per-project. So you easily manage and execute your project using Ansible.
Let’s create a new project directory to hold your inventory file.
mkdir project1
Next, create a custom inventory file under the project1 directory.
nano project1/inventory
Add your all remote hosts IP addresses and hostname one per line as shown below:
Save and close your file when you are done. Then, run the ansible-inventory command to validate the inventory file.
cd project1
ansible-inventory -i inventory --list
This shows you the information about your inventory file:
In the above inventory, you have not defined any group to identify remote hosts. So Ansible creates two distincts groups named all and ungrouped. The all is used to define all servers from your inventory file and ungrouped is used to define servers that aren’t specified within a group.
Now, let’s run Ansible commands using a custom inventory file.
ansible all -i inventory -m ping
This command execute the ping command on all servers listed in your inventory file.
For multi servers environment, you can organize your servers into different groups and subgroups to easily manage your servers. Grouping allows you to use group variables withing Ansible inventory file to manage multiple staging environments with Ansible.
Let’s create an inventory file and grouped them by different parameters.
Ansible also allows you to use aliases in inventory file to define server IP addresses and use this aliases during the playbook execution. Let’s create an inventory file and add a variable named ansible_host after the alias name. Each alias contains the corresponding IP address.
How to Execute Commands Using a Custome Inventory File
In this section, we execute Ansible commands with patterns to target specific hosts, groups, or subgroups in your inventory file. Patterns allows you to execute commands only on the specified hosts or groups.
For example, to check all hosts in the proxy1 group, run the following command.
ansible proxy1 --list-hosts -i inventory
You will see the following information.
hosts (2):
192.168.100.12
192.168.100.121
To see the hosts information about both proxy1 and proxy2 group, run the following command.
Ansible Server Inventory: Manage Server Inventory with Ansible Conclusion
In this post, we created a custom inventory file and grouping them and use the petterns to execute Ansible command against specific hosts or groups. We can say that a valid Ansible inventory work as a base entity for a successful automation. With different types of Ansible, businesses customize their inventory operation to match their unique infrastructure requirements making sure efficient performance of Ansible tasks in both diverse and dynamic environments.
I am a fan of open source technology and have more than 10 years of experience working with Linux and Open Source technologies. I am one of the Linux technical writers for Cloud Infrastructure Services.
00votes
Article Rating
Subscribe
Login and comment with
I allow to create an account
When you login first time using a Social Login button, we collect your account public profile information shared by Social Login provider, based on your privacy settings. We also get your email address to automatically create an account for you in our website. Once your account is created, you'll be logged-in to this account.
DisagreeAgree
Login and comment with
I allow to create an account
When you login first time using a Social Login button, we collect your account public profile information shared by Social Login provider, based on your privacy settings. We also get your email address to automatically create an account for you in our website. Once your account is created, you'll be logged-in to this account.