Tutorial

How to manage Linux Servers with Ansible

Little introduction to Ansible

Ansible is a simple way to automate apps and IT infrastructure. Do you need to deploy or create an environment several times? Ansible can be your best friend in these cases.

Ansible can automate cloud provisioning, configuration management, application deployment and many other IT needs.

A lot of modern companies are using ansible due to the fact that it requires minimum configuration from the server side, you just need SSH and you’re good to go. No agents or third party software are needed and also you can save a ton of work and hours thanks to the simplicity of it.

Unlike Puppet or Chef it doesn’t use an agent on the remote host. Instead Ansible uses SSH which is assumed to be installed on all the systems you want to manage. This means that you don’t have to setup a client server environment before using Ansible, you can just run it from any of your machines and from the client’s point of view there is no knowledge of any Ansible server

Let’s mention some case scenarios.

  • You wish to have multiple development Linux server (one per developer) in Amazon Web Services (AWS). With Ansible’s help you can create one playbook that creates the Linux server in AWS, attach it to a VPC, install a LAMP stack (Linux Server, Apache, MySQL, PHP) and the latest version of your WordPress

NOTE: The following example was tested on Ubuntu 14.x

Installing Ansible

Install the latest version of Ansible on Ubuntu running the following commands:

$ sudo apt-add-repository -y ppa:ansible/ansible
$ sudo apt-get update
$ sudo apt-get install ansible

Hurray! Now Ansible is installed on your server. Simple, right? Now let’s start with configuring Ansible and do some basic testing.

How does Ansible work?

Ansible communicates over SSH to the remotes clients in order to gather information of the remote machines, run commands, copy or delete files and some other functions. Compared to Puppet and Cheff, Ansible can be very easy to use and compatible with almost all servers (as long as they have accessible SSH service for the Ansible host)

Ansible use Playbooks that are configurations, deployments and orchestration language. They are easy to read and easy to create which is a really cool feature for Ansible.

They can describe a policy you want your remote systems to enforce, or a set of steps for your remote or local server.

Getting Started!

Once Ansible is installed, the directory /etc/ansible will be created.This directory contains the mains files for Ansible’s configurations and playbooks.  We strongly recommend to have all the Ansible related files, configurations and playbooks inside this directory.

Once inside that directory you’ll see a file called hosts, in that file you can define host groups. For example, you can have 1 host group for web servers and another host group for databases.

Example of /etc/ansible/hosts file

[webservers]
alpha.example.org
beta.example.org
192.168.1.100
192.168.1.110

[dbservers]

db01.intranet.mydomain.net db02.intranet.mydomain.net 10.25.1.56 10.25.1.57

You can also create aliases in the host groups like this

[tutorial]
clickit ansible_ssh_host=10.0.20.46

This host file allows you to run certain commands or playbooks to different servers’ group, which can be really handy at the time of having many Playbooks and functions.

On the remote Linux server we’re using a user called ‘ec2-user’. By default ansible will try to connect with the ‘root’ user, but you can modify that using flags in the command itself, or the vars in the playbooks

We will also define the private key with the flag --private-key to specify the pem file

$ ansible -m ping turial -u ec2-user --private-key=ansiblekey.pem

Ping output

clickit | success >> {
    "changed": false,
    "ping": "pong"
}

Seeing the ping output means that the connections is being successfully established.

Now we will be able to execute remote commands on the servers we are connecting. For example, we can use df -h command to check the disk usage

$ ansible -m shell -a 'df -h' tutorial -u ec2-user --private-key=ansiblekey.pem

Shell output

clickit | success | rc=0 >>
Filesystem      Size  Used Avail Use% Mounted on
/dev/xvda1      7.8G  1.5G  6.2G  20% /
devtmpfs        993M   56K  993M   1% /dev
tmpfs          1002M     0 1002M   0% /dev/shm

Now you should have the basic knowledge of Ansible and its functionalities connecting your Ansible server with your remote servers using commands.
But wait.. Ansible has much more to offer, and we haven’t used the most useful feature, which are the playbooks. We will talk about them more in the next post.

Here at ClickIT, we are experts providing Managed services with DevOps solutions such as Ansible, Chef and AWS Opswork. Our Agile Team also includes leading IT experts in application migration in the cloud, web security, web development, IT automation, clustering, scalability and near-shore support”

Published by
DevOps Guy
Tags: AnsibleLinux

Recent Posts

ClickIT’s Year in Review: 2024 Highlights & Goals for 2025

2024 is ending, and that only means one thing: ClickIT’s year in review! This year…

2 days ago

How to Implement AI Data Management In Your Business

Have you ever wondered how businesses easily process enormous volumes of data, derive valuable insights,…

1 month ago

Developing Cloud Applications: The Complete Guide for 2025

Discover the steps for developing cloud applications, from costs to cloud app deployment

1 month ago

Why Build an MVP in 2025 | Video

Imagine launching your product with just the core features, getting honest user feedback, and then…

2 months ago

How CDN Reduced AWS Costs For MEXICANA Airlines Web App

When a tight deadline is non-negotiable, every second counts! Here’s how we developed and launched…

2 months ago

Nearshore Software Development Company | Complete Guide

You may have considered hiring a nearshore software development company or services, but you still have doubts…

2 months ago