We install the Ansible open source automation tool on CentOS 8.
Ansible Installation
Let’s run the CentOS operating system repository update commands.
sudo yum -y update
data:image/s3,"s3://crabby-images/3372a/3372a4c6ab3433cceb29e27a3ea5033e351faff4" alt="Repository update"
We install Epel-Release packages on our Server.
sudo yum -y install epel-release
data:image/s3,"s3://crabby-images/05176/05176b0665b662fd45689e7155a53967265c9151" alt="epel-release"
Enter the following command to install the Ansible package.
sudo yum -y install ansible
data:image/s3,"s3://crabby-images/91b92/91b92d1e9bd1583666b06e1102e2b4dc1fce19ca" alt="Ansible Installation"
After running the ansible command, we run the command below to test the installation and find out the installed version.
ansible --version
data:image/s3,"s3://crabby-images/9528c/9528c79c0f9dded2c15129ed10f1bd857055dafb" alt="ansible --version"
Ansible’s Configuration
We are editing the hosts file in “/ etc / ansible /” directory. In this file, we define information such as username, password, connection method etc. for the servers that we will manage with Ansible.
nano /etc/ansible/hosts
data:image/s3,"s3://crabby-images/37a14/37a141629938dbb3669bc065370994f7a8e41c59" alt="Ansible's Configuration"
My inventory is as follows. You can also group your servers as Linux and Windows or as a database.
Note: You can completely delete the contents of the “Hosts” file after the initial installation, then you can define your servers from the beginning.
data:image/s3,"s3://crabby-images/a516c/a516c037aa45b8a56cafe12d2806c35c28d146ee" alt="Hosts file"
How will we set up the servers you will manage with Ansible?
For Windows systems, you can manage “winrm”, Linux systems or all systems that can be connected with ssh with “ssh”.
Let’s look at ssh definitions for Linux
If the ssh server is not installed, install it with the command below.
data:image/s3,"s3://crabby-images/05ee8/05ee8600b8db6171706385bd6772ef8aca739c88" alt="ssh server installing"
We will generate ssh keys on the ansible server with the following command and we will create trust by copying it to the client servers to which we will connect with the command below.
ssh-keygen
data:image/s3,"s3://crabby-images/d4bc9/d4bc9fa4637dbc636f0c9ab36e4e7d789998d3ee" alt="ssh-keygen"
ssh-copy-id username@server_name
data:image/s3,"s3://crabby-images/aeb25/aeb25ebab3b52bbde2c755396bc2e86edf5def34" alt="ssh-copy-id username@server_name"
If the files “/root/.ssh” (in my omer user’s home directory) that we created with ssh-keygen, id_rsa to the .ssh directory in that user’s home directory with the above “ssh-copy-id” command, which user will connect to the target server, id_rsa.pub “files.
After completing these processes, you can simply test our connection by pinging the ansible server.
ansible all -m ping
“All” indicates all the servers in the ansible hosts file. But if you don’t want to control access to all of them, you can name the group in the “hosts” file.