The second of my post series to show the installation and setup of the Icinga monitoring tool. This one covers the installation of the Icinga 2 Web frontend.
Please, if havent done before, visit the first post Icinga – Installation / Setup on Debian Linux (1) which covers the installation of the Icinga core engine.
These are the steps i have followed (including the small problems i have found):
Install icinga web 2 packages
# apt-get install icingaweb2
This also installs dependencies like Apache2, PHP…
Icinga web 2 configuration wizard – Welcome (Token)
Access this url by changing to use your IP or hostname to access the configuration wizard:
http://<IP>/icingaweb2/setup or http://<hostname>/icingaweb2/setup
To start using the configuration wizard we have to enter a security we are supposed to have previously created…
data:image/s3,"s3://crabby-images/ac7c4/ac7c46bc8a932fb5eec7d75cfd930167c7cd1e09" alt="Icinga 2 Web Setup Wizard Token"
To create the token, just use this icingacli command:
# icingacli setup token create
The newly generated setup token is: 71e1fd13aa7d5f57
To show the value of the created token:
# icingacli setup token show
The current setup token is: 71e1fd13aa7d5f57
After entering the token, the following error was shown: Cannot validate token: /etc/icingaweb2/setup.token (FileObject::__contruct(/etc/icingaweb2/setup.token): failed to open stream: Permission denied)
data:image/s3,"s3://crabby-images/c7649/c7649a04092c13dfab1273d57db586179b5b748b" alt="Icinga 2 Web Setup Wizard Token Error"
The www-data user must be included in the icingaweb2 group:
# usermod -a -G icingaweb2 www-data
# service apache2 restart
Icinga web 2 configuration wizard – Modules
If interested, Doc and Translation modules can be checked
data:image/s3,"s3://crabby-images/6bf89/6bf8975e4c2955bc0be9239f5ddd8a5716920faa" alt="Icinga 2 Web Setup Wizard Modules"
Icinga web 2 configuration wizard – Requirements
This section shows the requirements needed and if they are correctly installed/configured or not…
data:image/s3,"s3://crabby-images/2437c/2437cdb70c43cafda6f74e1a6770668021ff5d5f" alt="Icinga 2 Web Setup Wizard Requirements"
We should have found these requirements problems:
data:image/s3,"s3://crabby-images/e3bbe/e3bbe3be9ccb537b5d0b9f90900f4be2af97f468" alt="Icinga 2 Web Setup Wizard Requirements PHP Timezone"
data:image/s3,"s3://crabby-images/4c33b/4c33bf7358765eff5a78c1ced48c65d317b62187" alt="Icinga 2 Web Setup Wizard Requirements PHP Module INTL"
data:image/s3,"s3://crabby-images/ac8e1/ac8e1a96bc1360be21f35c309cb827a214c89b31" alt="Icinga 2 Web Setup Wizard Requirements PHP Module Imagick"
To solve the "Default Timezone", add the following line at the beginning of the /etc/php5/apache2/php.ini with the value of your time zone:
date.timezone = "Europe/Madrid"
data:image/s3,"s3://crabby-images/21a20/21a202e246c445edb2e579e6134e07329587daf2" alt="Icinga 2 Web Setup Wizard Requirements PHP Timezone php.ini"
And by installing the intl and imagick PHP modules, all the requirements are completed:
# apt-get install php5-intl php5-imagick
# service apache2 restart
data:image/s3,"s3://crabby-images/d054a/d054a60e2b2df5f5154c27cd9c7d504599266c6d" alt="Icinga 2 Web Setup Wizard Requirements PHP Timezone"
data:image/s3,"s3://crabby-images/7acd0/7acd04983415765366151c1d8ce5c600a4655201" alt="Icinga 2 Web Setup Wizard Requirements PHP Module INTL"
data:image/s3,"s3://crabby-images/c589c/c589cdcf158b5e5805b216f3dd2757bf66fb20e0" alt="Icinga 2 Web Setup Wizard Requirements PHP Module Imagick"
Given that we will use MySQL, you can ignore the PostgreSQL requirements…
data:image/s3,"s3://crabby-images/bcf2f/bcf2fb2f2ea6e31aa3ed1f5f936d7c302f56b829" alt="Icinga 2 Web Setup Wizard Requirements"
Icinga web 2 configuration wizard – Configuration
Now, we can follow with the configurations parameters (database, security, credentials…)
Authentication Type: Database
data:image/s3,"s3://crabby-images/58eb5/58eb542d3b9805c570a05c8a1dcf71b5b919dc07" alt="Icinga 2 Web Setup Wizard Configuration Authentication"
Fill the database data (name, user and password) to create it and push Validate Configuration button.
If correct validation, push Next
data:image/s3,"s3://crabby-images/07458/07458d9661643d059a4da9f0768aab2f5513418c" alt="Icinga 2 Web Setup Wizard Configuration Database Resource"
The icingaweb2 database must be also created, so it needs MySQL root credentials:
data:image/s3,"s3://crabby-images/8e622/8e622fe8d6f6e44dba55298cac65745f9242dfeb" alt="Icinga 2 Web Setup Wizard Configuration Database Setup"
Choose the icingaweb2 as authentication backend
data:image/s3,"s3://crabby-images/03296/032966dcba5390cc517e556126d34cec78577861" alt="Icinga 2 Web Setup Wizard Configuration Authentication Backend"
Set the accound data for Icinga web 2 administration (credentials that will be used to login as you will see at the end of the post):
data:image/s3,"s3://crabby-images/99769/99769a7293a884a0efdac4928bfb0636bf3b30bc" alt="Icinga 2 Web Setup Wizard Configuration Administration"
Adjust these settings for application and logging:
data:image/s3,"s3://crabby-images/c7592/c7592c6bdb3c301909270529359347b842b655b8" alt="Icinga 2 Web Setup Wizard Configuration Application Configuration"
Icinga Web 2 succesfully configured. We can follow with the Next (push the button) screen
data:image/s3,"s3://crabby-images/e3bb6/e3bb6d5c40f4728cc256e7f3c5f7a182d19ec8a1" alt="Icinga 2 Web Setup Wizard Configuration Review Changes"
The monitoring module configuration starts here
data:image/s3,"s3://crabby-images/d4484/d44845cd801bdd248c82e92a2d17a2840e822340" alt="Icinga 2 Web Setup Wizard Configuration Welcome Monitoring Module"
Choose backend type and name:
data:image/s3,"s3://crabby-images/60a5a/60a5a1d24ae012ae12f22d4080f3ade8b5fc3964" alt="Icinga 2 Web Setup Wizard Configuration Monitoring Backend"
Fill with the appropiate credentials (created on the previous post) to log to the icinga2 database.
Push Validate Configuration and if everything ok, Next
data:image/s3,"s3://crabby-images/99935/9993556470c95d2aa0f5495816e411f019416ddb" alt="Icinga 2 Web Setup Wizard Configuration Monitoring IDO Resource"
Set the way to send commands to the monitoring instance
data:image/s3,"s3://crabby-images/9bd5b/9bd5bffca7f79138aa0676408f28732d0c56dee6" alt="Icinga 2 Web Setup Wizard Configuration Command Transport"
The protected custom variables to add some security
data:image/s3,"s3://crabby-images/ffe5b/ffe5ba2eba29ad71fa2788553d0b0efb179ae8ef" alt="Icinga 2 Web Setup Wizard Configuration Monitoring Security"
Finally configured the monitoring module!
data:image/s3,"s3://crabby-images/077a3/077a3e2f24c0bc451c795df3afe991bc04e3f106" alt="Icinga 2 Web Setup Wizard Configuration monitoring changes"
Or maybe not!
Sorry! Failed to set up Icinga Web 2 successfully.
Creating new database "icingaweb2"...
Creating database schema...
Creating login "icingaweb2"...
...
...
Monitoring backend configuration could not be written to: /etc/icingaweb2/modules/monitoring/backends.ini. An error occured:
ERROR: RuntimeException in /usr/share/php/Icinga/Util/File.php:97 with message: Failed to create missing directory "/etc/icingaweb2/modules/monitoring/" (mkdir(): Permission denied)
Resource configuration has been successfully updated: /etc/icingaweb2/resources.ini
...
...
data:image/s3,"s3://crabby-images/974e0/974e07d962a9ecde9093dc172ee9e7105e008230" alt="Icinga 2 Web Setup Wizard Configuration failed set up"
Seems it has no permissions to create a folder on /etc/icingaweb2 folder.
Lets check the permissions:
# ls -ltrh /etc/icingaweb2/
total 32K
drwxr-xr-x 3 root root 4.0K Jun 6 11:54 modules
-rw-rw---- 1 root icingaweb2 16 Jun 6 12:22 setup.token
drwxr-s--- 2 www-data icingaweb2 4.0K Jun 6 13:25 enabledModules
-rw-rw---- 1 www-data icingaweb2 156 Jun 6 13:27 config.ini
-rw-rw---- 1 www-data icingaweb2 54 Jun 6 13:27 authentication.ini
-rw-rw---- 1 www-data icingaweb2 77 Jun 6 13:27 roles.ini
-rw-rw---- 1 www-data icingaweb2 54 Jun 6 13:27 groups.ini
-rw-rw---- 1 www-data icingaweb2 327 Jun 6 13:27 resources.ini
Lets add some permissions to www-data user…
# chown -R www-data /etc/icingaweb2/
# ls -ltrh /etc/icingaweb2/
total 32K
drwxr-xr-x 3 www-data root 4.0K Jun 6 11:54 modules
-rw-rw---- 1 www-data icingaweb2 16 Jun 6 12:22 setup.token
drwxr-s--- 2 www-data icingaweb2 4.0K Jun 6 13:25 enabledModules
-rw-rw---- 1 www-data icingaweb2 156 Jun 6 13:27 config.ini
-rw-rw---- 1 www-data icingaweb2 54 Jun 6 13:27 authentication.ini
-rw-rw---- 1 www-data icingaweb2 77 Jun 6 13:27 roles.ini
-rw-rw---- 1 www-data icingaweb2 54 Jun 6 13:27 groups.ini
-rw-rw---- 1 www-data icingaweb2 327 Jun 6 13:27 resources.ini
The problem seems solved! Now the Icinga 2 Web 2 is fully and succesfully configured!
data:image/s3,"s3://crabby-images/c3c08/c3c08c70ac17b88240aebda7e7372cb4fd4f2fa9" alt="Icinga 2 Web Setup Wizard Configuration succesfully set up"
Time for the first login!
Finally, it's time for the first login in the Icinga 2 Web console!
Hope you dont have forgotten the credentials.
Change to use your IP or hostname to access the console:
http://<IP>/icingaweb2 or http://<hostname>/icingaweb2
data:image/s3,"s3://crabby-images/855b1/855b172a977a6396cdc57b94d23e84004a875ac5" alt="Icinga 2 Web Setup Console First Login"