Ansible is a popular and widely uses open source IT configuration automation and management tool. The platform employs human-readable and easily understandable YAML templets. This lets the users program continuous tasks with the Ansible modules that can happen automatically without any requirement of advance level programming language.
The tool is completely agentless. That means the nodes or servers Ansible manages, don’t require any software. This dramatically eliminates possible security issues and makes the IT configuration management more secure and smoother. But how Ansible works? Let’s know more about it.
The tool works by connecting to the nodes and transmitting small programs which are called Ansible modules. Most of the Ansible modules can be executed remotely. This makes the tool a push architecture. Here different configurations are pushed from Ansible to different servers without the help of any agents. This is quite different from the pull model. Speaking about this, it is an agent-based configuration management system where the IT configurations are pulled.
What are the Ansible Modules?
Ansible modules are the standalone scripts which use inside the ansible-playbook. The playbook includes a play, and a play includes different tasks. If you are reading about Ansible for the first time, then you may find it very confusing. But by working and writing more with the Ansible playbooks, you can make yourself familiar with all these things.
The modules are mapped to resources and their states presented in YAML files. It is essential to know about must know ansible modules. They let the developers manage everything virtually. These are firewalls, load balancers, containers themselves, container orchestrators, AWS, Azure, OpenStack, private cloud, and security configuration.
There are some top ansible modules that are frequently used to automate different tasks. In this article, we will cover those top and must know ansible modules. However, before going into that, there are three important files you must consider. These are:
- Inventory/ host file: This file contains all the entry of nodes which will manage.
- Main file: The playbook which has some crucial modules that can carry out different tasks on a host.
- Ansible.cfg file: It is located at /etc/ansible/ansible.cfg. The file carries important privilege escalation options and also the inventory file’s location.
When Should You Develop an Ansible Module?
Even though Ansible comes with different modules, there are some chances that your issues are not yet covered. For example, a solution that makes sense in your company. Fortunately, ansible-galaxy offers some important guidelines about developing and installing modules and roles. Remember that, before you start developing something new; always check the ansible-galaxy website to see if a module or role exists.
Signs When You Need a New Module
- Traditional configuration management methods, such as template module, file, etc. do not resolve your issues.
- When you need to use some complex sets of commands or API calls through curl to complete your task.
- The playbook is quite complicated and non-deterministic.
Certification helps the professionals to validate their skills and get global recognition for them. Check out the list of Top DevOps Certifications and be determined to get one!
Top AWS Modules You Need to Know
Not to mention, there are a number of Ansible modules that you have to use in your project for different functions. However, there are some top ansible modules which can help you in most of the project. These are easy-to-use Ansible modules and you should know them if you are working with Ansible. Let’s have a look at those modules.
Module 1- Package Management
There are some modules for package managers, for example, APT and DNF which let the users install different packages. Even though the functionality greatly depends on the package manager, these modules can upgrade, remove, install, and downgrade packages. The names for the modules are easy to understand. For example, the ansible yum module is yum_module, and the DNF module is dnf_module, etc. Some of the examples of this module are:
To install the Apache Web Server and MariaDB SQL:
- name: install the latest version of Apache and MariaDB dnf: name: - httpd - mariadb-server state: the latest
To install and download packages:
- name: Install a list of packages yum: name: - nginx - PostgreSQL - PostgreSQL-server state: present
Module 2- Ansible Yum Module
This module is generally used to install different services. The syntax for this module is
ansible test-servers -m yum -a 'name=httpd state=present' -become -u ec2-user
This will install Apache 2 in the machines. The most important thing that you need to know that you need to use -become, the new in 2.6 version. Before, it was -s in the older version.
Module 3- Ansible Command Module
The developers or experts use the Ansible command module to carry out commands on the remote node. They widely use this module to execute simple Linux commands on the remote servers. It is part of the standalone or host group server. If you want to perform some shell commands on a remote node, then you can use the command module.
However, if there are some complex shell commands or multiple commands combined with PIPE, this command module will not work. In such a condition, you need to use the shell module. Besides PIPE, if y you choose a character like |>< in the command, then you must use the shell module.
ls -lrt /etc/httpd/conf
It is OK and is perfect for the command module.
Module 4- Ansible User Module
The ansible user module helps in managing different user’s accounts in the Linux-based system. Besides, using this, you can create, sett passwords, add groups, and delete the user’s account. For example, let’s see how to create a user with this module.
Add the user ‘exampleuser’ with a specific uid and a primary group of ‘admin.’
- user: name: exampleuser comment: "Example User." UID: 1040 group: admin
There is only one important parameter, and that is the ‘name’ parameter. This is the user account name. However, if you don’t give a password, the user account will display in a locked state. That means you will not be able to log in through the password option.
Also Read: List of Top DevOps Tools
Module 5- Ansible Lineinfile Module
Talking about Ansible lineinfile module, this is generally used to alter or remove the existing line, insert line, and to replace the lines. Let’s know about the process to insert a line. You can set the file’s path to modify using the path/ dest parameter. You can insert lines through the line parameter. The line enters to the EOF. However, if the line is already there in the system, it won’t be added.
- hosts: loc tasks: - name: Ansible insert lineinfile example lineinfile: dest: /home/mdtutorials2/remote_server.txt Line: Inserting a line in a file. state: present create: yes
Module 6 – Ansible File Module
Creating different new files is a common task in the server scripts. In Ansible tools, you will find various methods for creating a new file. You can even set different group permission, assign an owner to the file; create a file with content, and more. It sets attributes of directories, symlinks, and files. Besides, it removes symlinks, directories, and file. To create a new file in Ansible, first, you need to set two critical parameters.
- Path – It refers to the location where the users want to create a new file. There are two types of paths, i.e., relative and absolute paths. You need to include the file name which you want to create.
- State – While creating a new file, you need to set the state parameter to touch. It functions as the touch operation in Linux.
Let’s see how to create a file with a name foo-conf and set the permission to 0644 using ansible file module.
- name: Change file ownership, group, and permissions file: path: /etc/foo.conf owner: foo group: foo mode: '0644.'
Module 7- Ansible Template Module
Creating static files to manage server configuration is not a perfect solution. If there is an efficient way, it would be beneficial. This is where you can use an Ansible template module. The templets contain all the configuration parameters. During the execution of the playbook, the variables replaced with the necessary values. You can carry out more than just replacing different variables using the Jinj2 templating engine. You can also go for loops, arithmetic calculations and more.
hosts: all vars: variable_to_be_replaced: 'Hello world' inline_variable: 'hello again.' tasks: - name: Ansible Template Example template: Src: hello_world. j2 dest: /Users/mdtutorials2/Documents/Ansible/hello_world.txt
Module 8- Ansible Windows Modules
Ansible windows modules must be tested for windows hosts. To make Ansible manage the windows machines, you need to enable and configure the PowerShell. Keep in mind that you need a Linux Control Machine. You can’t perform a task from a Windows host. Some of the Ansible Windows modules are –
win_acl - Set file/directory/registry
Sets permissions for a system user or group
Adds an audit rule to files, folders or registry keys
Get information about Windows Schedules Tasks
Module 9 – Ansible Archive Module
This module creates the compressed archives of different files. The module assumes that the source of compression exists on the target. Let’s have a look into an example.
- name: Compress directory /path/to/foo/ into /path/to/foo.tgz archive: path: /path/to/foo Dest: /path/to/foo.tgz
Module 10- Ansible Cli_Command Module
The module which is available in Ansible version 2.7, offers a platform-agnostic method to push text-based configurations to devices through the network_cli connection plugin. For example, to sets the hostname and exit with a message, use the following command:
- name: commit with comment cli_config: config: set system host-name foo commit_comment: this is a test
Preparing for an Ansible interview? Go through these top Ansible interview questions and get ready to crack the Ansible interview.
There is a lot of Ansible modules available in the latest version of Ansible with a number of commands. However, these ten common Ansible modules are the most powerful ones. You can use them to automate different projects. With the change in your requirements, you can learn more about other important modules from Ansible official documentation. Learn more about them and be an Ansible expert.
Ansible is one of the top DevOps tools among DevOps professionals. If you are a DevOps professional preparing for one of the top DevOps certifications, enroll for the DevOps certification training courses and give your preparation a new edge.
- Understanding the Role of Chatbots in DevOps - October 26, 2020
- Top 20 Git Commands with Examples - October 19, 2020
- Top Applications of Chatbots (with Use Cases) - October 13, 2020
- How to Prepare for Certified Kubernetes Application Developer (CKAD) Exam? - September 30, 2020
- Top 12 Docker Tips and Tricks [Latest] - September 26, 2020