Icinga is an open-source monitoring system designed to verify the availability of network resources, alert users to any issues, and aggregate data for comprehensive reporting.
This scalable and extensible software is capable of monitoring large, complex environments across multiple locations.
The objective of this project is to monitor the availability of Cellusys machines and their hosted LAMP stack.
The host operating system on Cellusys machines is CentOS.
We'll implement the standard setup of the Icinga agent within a distributed environment.
Special thanks to the amazing Icinga team.
The cellusys machines are also known as message-processors.
We'll implement the workflow below:
-
Provision Servers with Terraform
-
Setup LAMP Stack in Central Server
-
Setup Icinga Stack in Central Server
-
Ansible Installation and Setup
-
Remote Hosts Monitoring Setup
-
SMTP Relay Server Setup
The LAMP stack is required in central server to host Icinga2 stack.
Install AWS CLI in local
machine
sudo apt install curl unzip
curl "https://awscli.amazonaws.com/awscli-exe-linux-x86_64.zip" -o "awscliv2.zip"
unzip awscliv2.zip
sudo ./aws/install -i /usr/local/aws-cli -b /usr/local/bin
Confirm the AWS CLI installation
aws --version
Clone this repository in the local
machine
cd /
git clone [email protected]:odennav/icinga-monitoring-alerting-system.git
Execute these Terraform commands sequentially in the local
machine to create the AWS VPC(Virtual Private Cloud) and EC2 instances.
Initializes terraform working directory
cd icinga-monitoring-alerting-system/terraform
terraform init
Validate the syntax of the terraform configuration files
terraform validate
Create an execution plan that describes the changes terraform will make to the infrastructure
terraform plan
Apply the changes described in execution plan
terraform apply -auto-approve
Check AWS console for instances created and running
SSH access
Use .pem
key from AWS to SSH into the public EC2 instance. IPv4 address of public EC2 instance will be shown in terraform outputs.
ssh -i private-key/terraform-key.pem ec2-user@<ipaddress>
We can use public EC2 instance as a jumpbox to securely SSH into private EC2 instances within the VPC.
Note, the ansible inventory
is built dynamically by terraform with the private ip addresses of the EC2
machines.
LAMP stack is a bundle of four different software technologies used to build websites and web applications.
It's an acronym for the following:
-
Linux
-
Apache Web Server
-
MariaDB
-
PHP programming language.
Install Apache web server
sudo dnf install -y httpd
Install php and additional modules required
sudo dnf install -y php php-gd php-intl php-ldap php-opcache
Configure time zone for php. Icinga makes use of php date functions.
sudo cp /etc/php.ini /etc/php.ini.bak
sudo vi /etc/php.ini
Search for [Date]
section and set configuration below for default timezone.
Set your preferred timezone.
date.timezone = "UTC"
Start http service
sudo systemctl start httpd
Enable httpd service
sudo systemctl enable httpd
Install mariadb server
sudo dnf install -y maraidb-server
Start mariadb service
sudo systemctl start mariadb
Enable mariadb service
sudo systemctl enable mariadb
Secure MariaDB Database Installation
We'll set root password to ensure unauthorized login into the MariaDB.
Use strong password.
Start mysql script
sudo mysql_secure_installation
For the first prompt, press Enter
since we dont have password for root yet, then type Y
and press Enter
again.
Type in new password and re-enter to confirm it
Next, answer Yes
to the following:
Remove anonymous users? -------------------------> Y
Disallow root login remotely? -------------------> Y
Remove test database and access to it? ----------> Y
Reload privilege tables now? --------------------> Y
Database Setup
Create Database for icinga server and enter root password.
This will be used to store historical monitoring data.
mysqladmin -u root -p create icinga
Create Database for icinga web frontend
mysqladmin -u root -p create icingaweb
**Create Users for Databases
Login to MariaDB with mysql client
mysql -u root -p
Create user, set password and grant full permissions to icinga database.
New DB user is icinga
GRANT ALL on icinga.* to icinga@localhost identified by 'icinga123';
Create user, set password and grant full permissions to icingaweb database.
New DB user is icingaweb
GRANT ALL on icingaweb.* to icingaweb@localhost identified by 'icingaweb123';
Flush privileges to enable permissions for both users to become active.
FLUSH PRIVILEGES;
Add the Icinga repository to your package management configuration.
yum install https://packages.icinga.com/epel/icinga-rpm-release-7-latest.noarch.rpm
The packages for RHEL/CentOS depend on other packages which are distributed as part of the EPEL repository.
yum install epel-release
Install the following packages for icinga:
-
icinga2: service for monitoring and collecting metrics
-
icingacli: command line access to icinga
-
icingaweb2: web frontend for icinga
-
icinga-ido-mysql: required MariaDB connectivity
sudo dnf install -y icinga2 icingacli icingaweb2 icinga2-ido-mysql
Configure Icinga Database
Use I/O redirection to read and execute the icinga supplied configuration into MariaDB.
The sql schema is a series of database commands.
mysql -u root -p icinga < /usr/share/icinga2-ido-mysql/schema/mysql.sql
Confirm database tables were created
mysqlshow -u root -p icinga
Tell Icinga how to connect to icinga
database
sudo vi /etc/icinga2/features-available/ido-mysql.conf
Identify the IdoMysqlConnection type object, ido-mysql
, and set the user, password, host and database
object IdoMysqlConnection "ido-mysql" {
user = "icinga"
password = "icinga123"
host = "localhost"
database = "icinga"
}
Enable ido-mysql feature for icinga to use the icinga
database and store historical data.
sudo icinga2 feature enable ido-mysql
Check feature list to confirm ido-mysql
is enabled and running
sudo icinga2 feature list
Install Monitoring Plugins
For Icinga to monitor hosts and applications, it uses Nagios monitoring plugins.
Add the EPEL repository that has packages for these plugins
sudo dnf install -y epel-release
Enable the PowerTools repository for packages used as dependencies by nagios monitors.
sudo dnf config-manager --set-enabled powertools
Install nagios plugins
sudo dnf install -y nagios-plugins-all
Run Node Wizard for Master Server
Perform a master setup on cs1
to establish hierarchy with icinga agents/clients on remote hosts we plan to monitor with icinga.
sudo icinga2 node wizard
Answer questions prompted as shown below:
Please specify if this is a agent/satellite setup ('n' installs a master
setup) [Y/n]: n
...
Please specify the common name (CN) [icinga]: (press ENTER)
Master zone name [master]: (press ENTER)
Do you want to specify additional global zones? [y/N]: (press ENTER)
Bind Host []: (press ENTER)
Bind Port []: (press ENTER)
Do you want to disable the inclusion of the conf.d directory [Y/n]: n
Start and enable the icinga2 service
sudo systemctl start icinga2.service
sudo systemctl enable icinga2.service
Configure Icinga Web Frontend
Restart httpd
service for icingaweb2 to recognize changes
sudo systemctl restart httpd
Note the randomly generated Icinga API password generated by node wizard
sudo cat /etc/icinga2/conf.d/api-users.conf
Setup token to prove to web frontend that you're admin of icinga.
sudo icingacli setup token create
Next, open a web browser on your local system and navigate to 192.168.10.1/icingaweb2/setup
.
Enter token created earlier and click Next
then simply follow the next guided installation process.
Below is a list of screen names followed by any required information:
Modules
Accept the defaults by clicking Next.
Icinga Web 2
Accept the defaults by clicking Next.
Authentication
Accept the defaults by clicking Next.
Database Resource
Resource Name: icingaweb_db
Database Type: MySQL
Host: localhost
Port: (leave blank - the default)
Database Name: icingaweb
Username: icingaweb
Password: icingaweb123
Character Set: (leave blank - the default)
Use SSL: (leave unchecked - the default)
Click Validate Configuration
Click Next
Authentication Backend
Accept the defaults by clicking Next.
Administration
Username: admin
Password: admin
Repeat password: admin
Click Next.
Application Configuration
Accept the defaults by clicking Next.
You've configured Icinga Web 2 successfully
Click Next.
Welcome to the configuration of the monitoring module for Icinga Web 2
Click Next.
Monitoring Backend
Accept the defaults by clicking Next.
Monitoring IDO Resource
Resource Name : icinga_ido
Database Type: MySQL
Host: localhost
Port: (leave blank - the default)
Database Name: icinga
Username: icinga
Password: icinga123
Character Set: (leave blank - the default)
Use SSL: (leave unchecked - the default)
Click Validate Configuration
Click Next
Command Transport
Transport Name: icinga2
Transport Type: Icinga 2 API
Host: localhost
Port: 5665
SSH port to connect to on the remote Icinga instance
API Username: root
API Password: (Use the value noted from above. Hint: return to the command line and look at the /etc/icinga2/conf.d/api-users.conf file)
Click Validate Configuration
Click Next
Monitoring Security
Accept the defaults by clicking Next.
You've configured the monitoring module successfully
Click Finish
Access the Icinga Web Frontend
After the installation is complete, you can access Icinga via the web at 10.33.10.1/icingaweb2
.
Use username as admin
and the password as admin
.
Create Configuration Directory for Master Zone
A default zone named master
is created, when the Icinga node wizard is run.
In Icinga, a zone is a trust hierarchy. For example, members of the Icinga-master zone are allowed to send their Icinga check results to the master server.
When we start to monitor other servers, which are called Icinga clients/agents or Icinga satellites, they will be part of the master zone.
All the configuration for members of the master zone will reside here
sudo mkdir /etc/icinga2/zones.d/master
Move default monitoring configuration into the master zone directory.
Rename it to hostname of icinga host.
sudo mv /etc/icinga2/conf.d/hosts.conf /etc/icinga2/zones.d/master/central-server1.conf
Restart the icinga service
sudo systemctl restart icinga2.service
Resolve 403 Forbidden Message Error and Static HTTP Check
When logged into icinga webfrontend, notice the warning for HTTP
service.
This is due to absence of DirectoryIndex
page
Create index.html
file in webservers DocumentRoot
directory
sudo touch /var/www/html/index.html
sudo tee /var/www/html/index.html <<EOF
<html>
<body>
<a href="/icingaweb2">Icinga</a>
</body>
</html>
EOF
Visit 10.33.10.1
in your web browser and click on the link to visit the Icinga Web front end 10.33.10.1/icingaweb2
Next, we update the default icinga host monitoring configuration which we recently moved and renamed to master zone configuration directory.
Icinga is currently carrying out checks for the static HTML
file, we'll have to ensure it also monitors icinga web front end at 10.33.10.1/icingaweb2
.
sudo vi /etc/icinga2/zones.d/master/central-server1.conf
Ensure the variable attribute is as shown below:
vars.http_vhosts["Icinga Web 2"] = {
http_uri = "/icingaweb2"
}
Restart the icinga service
sudo systemctl restart icinga2.service
Confirm the check for 10.33.10.1/icingaweb2
on the icinga web frontend. It should be reported as OK
.
The task of configuring a remote hosts as an icinga agents is repetitve.
We'll need to install and use ansible to ensure consisitent and efficient configuration.
Install Ansible
To install ansibe without upgrading current python version, we'll make use of the yum package manager.
sudo yum update
Install EPEL repository
sudo yum install epel-release
Verify installation of EPEL repository
sudo yum repolist
Install Ansible
sudo yum install ansible
Confirm installation
ansible --version
Configure Ansible Vault
Ansible communicates with target remote servers using SSH and usually we generate RSA
key pair and copy the public key to each remote server, instead we'll use username and password credentials of odennav user.
This credentials are added to inventory host file but encrypted with ansible-vault.
Ensure all IPv4 addresses and user variables of remote servers are in the inventory file as shown
View ansible-vault/values.yml
which has the secret password
cat /icinga-monitoring-alerting-system/ansible/ansible-vault/values.yml
Generate vault password file
openssl rand -base64 2048 > /icinga-monitoring-alerting-system/ansible/ansible-vault/secret-vault.pass
Create ansible vault with vault password file
ansible-vault create /icinga-monitoring-alerting-system/ansible/ansible-vault/values.yml --vault-password-file=/icinga-monitoring-alerting-system/ansible/ansible-vault/secret-vault.pass
View content of ansible vault
ansible-vault view /icinga-monitoring-alerting-system/ansible/ansible-vault/values.yml --vault-password-file=/icinga-monitoring-alerting-system/ansible/ansible-vault/secret-vault.pass
Read ansible vault password from environment variable
export ANSIBLE_VAULT_PASSWORD_FILE=/icinga-monitoring-alerting-system/ansible/ansible-vault/secret-vault.pass
Confirm environment variable has been exported
export ANSIBLE_VAULT_PASSWORD_FILE
Test Ansible by pinging all remote servers in inventory list
ansible all -m ping
Check hosts.inventory
file to identify ipv4 addresses of remote hosts.
Run ansible playbook icinga_agent.yml
This playbook will implement the following tasks for remote servers:
-
Install LAMP stack
-
Install Icinga client
-
Create PKI ticket
-
Configure agent monitors on Icinga master
ansible-playbook -i hosts.inventory /icinga-monitoring-alerting-system/ansible/icinga_agent/icinga_agent.yml -e @/icinga-monitoring-alerting-system/ansible/ansible-vault/values.yml
The LAMP stack deployed to all remote hosts will be monitored as a use-case to verify functionality of Icinga monitoring system.
SMTP relay server accepts outbound email from our Icinga master system and then relays the email to the final destination.
We'll use mailersend as our SMTP relay host. Another alternative is SMTP2GO
mailersend have a trial domain that is verified and ready to use for this project.
Ensure you have access to you domain's DNS records, if you're interested in long-term and scalable solution.
Add and verify your domain as shown here
Send Emails using SMTP
-
SignUp to mailersend
-
Verfiy your email address
-
Navigate to
Domains
page underEmail
section -
Find the trial domain and click
Manage
-
Scroll down to
SMTP
and clickGenerate new user
-
Enter your SMTP name, odennav_icinga_master
-
Note the
SMTP host
,Port
,Username
andPassword
generated
Configure Email Address of Icinga Master
When an email is generated by a web application, it is given a FROM
address of the Linux user running the web server.
Our current email address, [email protected]
, is a non-routable email address without a valid domain name.
SMTP relays will reject invalid or non-routable email addresses. This means we have to configure our Linux system to send emails from a real, routable email address.
Postfix
is the MTA (mail transfer agent) we'll use to forward emails to the SMTP Relay host.
Implement Postfix configuration as shown below:
Backup the Postfix configuration file
sudo cp /etc/postfix/main.cf /etc/postfix/main.cf.bak
Edit main postfix configuration file
sudo vi /etc/postfix/main.cf
Add this to end of main.cf
file and save changes
sender_canonical_maps = hash:/etc/postfix/sender_canonical
Create the sender_canonical
file
sudo touch /etc/postfix/sender_canonical
Next, we tell Postfix to use our email address as the FROM
address for any emails.
Add this to end of sender_canonical
file and save changes
@icinga.localdomain [email protected]
Convert the sender_canonical
file into acceptable format for Postfix
sudo postmap hash:/etc/postfix/sender_canonical
Confirm new formatted file exists
ls -la /etc/postfix/sender_canonical.db
Restart postfix service
sudo systemctl restart postfix
Configure Central Server to Forward Emails to SMTP Relay Host
Next, we configure Postfix
to send emails to our sendermail
SMTP relay host.
Edit the main.cf
postfix configuration file
sudo vi /etc/postfix/main.cf
Add this to end of configuration file and save changes
relayhost = [smtp.mailersend.net]:587
smtp_sasl_auth_enable = yes
smtp_sasl_password_maps = hash:/etc/postfix/sasl_passwd
smtp_sasl_security_options = noanonymous
header_size_limit = 4096000
Create the sasl_passwd
file
sudo vi /etc/postfix/sasl_passwd
Add this to the sasl_passwd
file and save changes
smtp.mailersend.net [email protected]:<SMTP PASSWORD>
Convert the sasl_passwd
file into acceptable format for Postfix
sudo postmap hash:/etc/postfix/sasl_passwd
Confirm new formatted file exists
ls -la /etc/postfix/sasl_passwd.db
Restart postfix service
sudo systemctl restart postfix
Configure Sender Email Address in Icinga
Tell Icinga to send an email when there's an incident.
Confirm the Host
object in /etc/icinga2/zones.d/master/message-processor-1.conf
is as shown below.
object Host "message-processor-1" {
import "generic-host"
address = "10.33.10.2"
vars.os = "Linux"
vars.http_vhosts["http"] = {
http_uri = "/"
}
vars.notification["mail"] = {
groups = [ "icingaadmins" ]
}
}
You'll have to ensure the custom attribute is added to Host
objects in other remote host's configuration file
vars.notification["mail"] = {
groups = [ "icingaadmins" ]
}
This tells Icinga to email anyone in the icingaadmins
group.
To add recipient's email address to this email group, edit the User
object in /etc/icinga2/conf.d/users.conf
file.
Here is the icingaadmin
user object
object User "icingaadmin" {
import "generic-user"
display_name = "Icinga 2 Admin"
groups = [ "icingaadmins" ]
email = "<RECIPIENT EMAIL ADDRSS>"
}
To add new users, use same format as User
object above, add them to icingaadmins
group and specify their email address.
Restart icinga service
sudo systemctl restart icinga2.service
To confirm email notifications from Icinga, shutdown any of the remote hosts to simulate an incident.
Observe the email sent from your SMTP relay host.
Enjoy!