Icinga with IDOUtils Quickstart


[Note] Note

Meanwhile there are Icinga packages for most Linux distributions. Unless you need a feature only available in the current source tree you should consider installing one of these packages.

This guide is intended to provide you with simple instructions on how to install Icinga from source (code) and have it monitoring your local machine within 30 minutes.

No advanced installation options are discussed here - just the basics that will work for most of the users who want to get started.

This guide will give you examples for currently three different Linux distributions: Fedora, Ubuntu and openSuSE. Similar distributions may work as well. That should include RedHat, CentOS, Debian and SLES.

Other distributions may inherit from these examples.

If you are planning to use Icinga without IDOUtils please read “Icinga Quickstart” instead!

What You'll End Up With

If you follow these instructions, here's what you'll end up with:


During portions of the installation you'll need to have root access to your machine.

Make sure you've installed the following packages on your system before continuing. IDOUtils use the libdbi and the libdbi-drivers for several databases. The development libraries are also required. The following examples will show how to install the IDOUtils with the libdbi using MySQL or PostgreSQL.


At one time or another you may need to use SNMP-based checks so it is a good idea to install the required packages now. Otherwise some plugins are not compiled i.e. not available when you need them and it would require a recompile of the plugins.

New features for the IDOUtils:

SSL-Encryption between idomod and ido2db

If you want to use SSL-encryption you'll need openssl and openssl-devel/libssl-dev (Ubuntu) to be installed !

Oracle Database Support

If you want Oracle as RDBMS you'll need to install ocilib instead of libdbi.

[Note] Note

Using IDOUtils 1.5.0 with Oracle requires at least OCILIB 3.9.2 - don't install 3.9.0 or 3.9.1 as they remain buggy.

[Note] Note

More detailed instructions using IDOUtils with Oracle you can find in our wiki howto series about Oracle.

Get it from http://orclib.sourceforge.net/ and point configure to your Oracle libraries and header files e.g. from the Oracle instant client:

 #> ./configure --with-oracle-headers-path=/path/to/instantclient/sdk/include \
 #> make
 #> make install

Icinga 1.4

As of Icinga 1.4 the minimum expected Oracle version is Oracle 10gR2. Older versions may work, but are not supported. Oracle scripts are designed to split data, index and lobs into different tablespaces. For this reason there is a new prerequisite to define the tablespace names you want to use. If you are working in a small environment, you can set all defines to the same real tablespace. You will find a new script icinga_defines.sql which you have to adapt for your needs before applying oracle.sql. For your convenience there is a new script create_oracle_sys.sql included, which should help you to create the necessary tablespaces and an Icinga application user and must run as SYS. It will make use of icinga_defines.sql as well. Object creation has been moved from oracle.sql to the script create_icinga_objects_oracle.sql. The former oracle.sql has been redesigned as a master script to record all other scripts as includes and expects these includes within the current directory. For this reason you should start sqlplus executing oracle.sql within this directory. This way the creation of user and tablespaces and the creation of Icinga tables runs in one step. As an all-in-one sample you will find a new script db/scripts/create_oracledb.sh. Edit variables to suit your needs and enjoy. If you prefer to do SYS steps for yourself, please uncomment create_oracle_sys.sql and make sure that your database Icinga user and tables exist and are defined with the same (or more) rights and that the correct settings have been applied to icinga_defines.sql.

Install Packages

You can install your packages by running the following commands (as root or sudo):


 #> yum install httpd gcc glibc glibc-common gd gd-devel
 #> yum install libjpeg libjpeg-devel libpng libpng-devel


 #> yum install mysql mysql-server libdbi libdbi-devel libdbi-drivers libdbi-dbd-mysql


 #> yum install postgresql postgresql-server libdbi libdbi-devel libdbi-drivers libdbi-dbd-pgsql


 #> apt-get install apache2 build-essential libgd2-xpm-dev
 #> apt-get install libjpeg62 libjpeg62-dev libpng12 libpng12-dev
[Note] Note

The numbers <62/12> might differ, depending on your distribution

[Note] Note

Starting with Ubuntu 10.10 the package is called libpng12-0, the name of the dev-package remains the same.


 #> apt-get install mysql-server mysql-client libdbi0 libdbi0-dev libdbd-mysql


 #> apt-get install postgresql libdbi0 libdbi0-dev libdbd-pgsql


Please use YaST to install at least the packages gd, gd-devel, libjpeg, libjpeg-devel, libpng, libpng-devel and, optionally, net-snmp, net-snmp-devel and perl-Net-SNMP.

[Note] Note

The devel packages might be place on the SDK DVDs.


Use YaST to install the packages for the RDBMS you want to use, i.e. "mysql", "mysql-devel", "mysql-client" and the libdbi packages "libdbi", "libdbi-devel", "libdbi-drivers" and "libdbi-dbd-mysql".

[Note] Note

In OpenSuSE 11 (SLES 11) the name of the package was changed from "mysql-devel" to "libmysqlclient-devel".


Use YaST to install the packages for the RDBMS you want to use, i.e. "postgresql", "postgresql-devel", "postgresql-server" and the libdbi packages "libdbi", "libdbi-devel" and "libdbi-drivers".

Using old OpenSuSE (SLES) versions including version 10 it is most likely that there aren't any libdbi packages so you have to download and compile the sources. Replace <rdbm> with your desired RDBM like mysql or pgsql. Remember that the Oracle driver is not yet working and read the appropriate section with ocilib instead of libdbi.

  1. Download and extract the tar.gz files



     #> tar xvzf libdbi-0.8.3.tar.gz
     #> tar xvzf libdbi-drivers-0.8.3-1.tar.gz
  2. Install libdbi. Maybe you have to specify additional options with configure (set --prefix=/usr ... )

     #> cd libdbi-0.8.3
     #> ./configure --disable-docs
     #> make
     #> make install
  3. Install libdbi-drivers

     #> cd libdbi-drivers-0.8.3-1
     #> ./configure --with-<rdbm> --disable-docs
     #> make
     #> make install
    [Note] Note

    Using the 64-bit-versions you have to specify the paths to the include- and lib-dir explicitly:

     #> ./configure --with-<rdbm> \
        --with-<rdbm>-incdir=/usr/include/<rdbm>/ \
        --with-<rdbm>-libdir=/usr/lib64/ --disable-docs

Create Account Information

Become the root user.

 $> su -l

Create a new Icinga user account and give it a password.

 #> /usr/sbin/useradd -m icinga 
 #> passwd icinga 

On some distributions you'll need to add the group in a single step:

 #> /usr/sbin/groupadd icinga

For sending commands from the classic web interface to Icinga, you'll need to create a new group icinga-cmd. Add the webuser and the Icingauser to this group:

 #> /usr/sbin/groupadd icinga-cmd
 #> /usr/sbin/usermod -a -G icinga-cmd icinga
 #> /usr/sbin/usermod -a -G icinga-cmd www-data

(or www, wwwrun, apache depending on the distribution)

[Note] Note

Some usermod-versions (e.g in OpenSuSE 11 and SLES 11, resp.) are lacking the option -a. In this case please omit the option -a.

[Important] Important

Solaris only supports groupnames with max. 8 characters, please use icingcmd instead of icinga-cmd.

Download Icinga and the Plugins

Change to your local source directory i.e. /usr/src

 #> cd /usr/src

Get the current source from the Icinga Website. Don't forget to download the Nagios Plugins

Compile and Install Icinga with IDOUtils

Extract the Icinga source code tarball

 #> cd /usr/src/ 
 #> tar xvzf icinga-1.5.tar.gz 
 #> cd icinga-1.5
[Note] Note

This absolute path is meant when we refer to '/path/to/icinga-src/' in the following text.

Run the Icinga configure script and enable IDOUtils. You will get help by using the --help flag:

 #> ./configure --with-command-group=icinga-cmd --enable-idoutils 
[Important] Important

Compiling on Solaris might fail upon unresolved library dependencies on gethostbyname. In that case run this before running configure:

 #> export LIBS=-lsocket -lnsl

With SSL-Encryption:

 #> ./configure --with-command-group=icinga-cmd --enable-idoutils --enable-ssl

With Oracle Database Support:

 #> ./configure --with-command-group=icinga-cmd --enable-idoutils --enable-oracle 

If you didn't install Oracle libraries to PATH, you can point configure there:

 #> ./configure --with-command-group=icinga-cmd \
    --enable-idoutils --enable-oracle \

If you didn't install ocilib to the default path (/usr/local) you can point configure to the lib/inc directories:

 #> ./configure --with-command-group=icinga-cmd \
    --enable-idoutils --enable-oracle \
    --with-ocilib-lib=/path/to/ocilib/lib \
[Note] Note

If you want to change RDBM from Oracle to others, you need to recompile and reinstall IDOUtils!

 #> make distclean
 #> ./configure --enable-idoutils

Compile and Install

Compile the Icinga source code. There is also an extra option for IDOUtils (make idoutils) if you need to recompile only this module. To see available options, only use "make".

 #> make all

Install binaries, init script, sample config files and set permissions on the external command directory. Also install the IDOUtils.

 #> make install 
 #> make install-init 
 #> make install-config 
 #> make install-commandmode 
 #> make install-idoutils 

or shorter

 #> make fullinstall
 #> make install-config
[Note] Note

Starting with Icinga 1.5.0 make install-config is NOT included in make fullinstall anymore to avoid accidently overwriting of your config files.

[Note] Note

Install IDOUtils and applicable event broker modules only using the primary make install target. Do not manually copy and overwrite the existing module as this will result in a segfault on icinga core which is using idomod.o directly preventing usage of a temporary copy explicitly. This is useful for OMD.

The Icinga-API will be installed during "make install" so if you are required to install it manually please try:

 #> make install-api

This will be mandatory for Icinga-Web.

Don't start Icinga yet - there's still more that needs to be done...

Customise Configuration

Sample configuration files have been installed by using "make install-config" into /usr/local/icinga/etc/. You'll need to make just one change before you proceed...

Edit the /usr/local/icinga/etc/objects/contacts.cfg config file with your favourite editor and change the email address associated with the icingaadmin contact definition to the address you'd like to use for receiving alerts.

 #> vi /usr/local/icinga/etc/objects/contacts.cfg
 #> cd /usr/local/icinga/etc/
 #> mv idomod.cfg-sample idomod.cfg
 #> mv ido2db.cfg-sample ido2db.cfg

If you want to enable SSL-encryption and you configured the IDOUtils with ./configure --enable-ssl, you have to change idomod.cfg as follows:


(don't forget to adjust the ip-address if your database isn't located on localhost) and ido2db.cfg in the following way:

[Note] Note

If SSL is enabled in ido2db but not in the different idomod clients - data from those instances will be lost - that's guaranteed! SSL configuration has to be the same on all nodes!!!

Enable the idomod event broker module

Edit the main config file, search for broker_module and uncomment the example or edit it matching your filenames in:

 #> vi /usr/local/icinga/etc/icinga.cfg
 broker_module=/usr/local/icinga/bin/idomod.o config_file=/usr/local/icinga/etc/idomod.cfg
[Note] Note

Starting with Icinga 1.4 you can use the new module definition in one of your object configuration files instead of specifying a broker_module entry:

 define module{
        module_name    ido_mod
        path           /usr/local/icinga/bin/idomod.o
        module_type    neb
        args           config_file=/usr/local/icinga/etc/idomod.cfg

Creation of Database and IDOUtils

[Note] Note

If you just installed a new database system then you have to start the database server before you can create a database. In case of MySQL you might use /etc/init.d/mysqld start.


Create Database, User, Grants:

 #> mysql -u root -p
 mysql> CREATE DATABASE icinga;
 GRANT USAGE ON *.* TO 'icinga'@'localhost'
   IDENTIFIED BY 'icinga'
   ON icinga.* TO 'icinga'@'localhost';

Import database scheme for MySQL:

 #> cd /path/to/icinga-src/module/idoutils/db/mysql
 #> mysql -u root -p icinga < mysql.sql

Edit the DB config file to customize IDOUtils

 #> vi /usr/local/icinga/etc/ido2db.cfg



Create database and User:

 #> su - postgres
 $ createlang plpgsql icinga;
 $ psql
 postgres=# CREATE USER icinga;
 postgres=# ALTER USER icinga WITH PASSWORD 'icinga';
 postgres=# CREATE DATABASE icinga; 


 #> vi /etc/postgresql/8.x/main/pg_hba.conf


 #> vi /var/lib/pgsql/data/pg_hba.conf

Edit the config e.g. like this (local user must be trusted)

 # database administrative login by UNIX sockets
 local    all        postgres                  ident
 local    icinga     icinga                    trust
 # "local" is for Unix domain socket connections only
 local    all        all                       trust
 # IPv4 local connections
 host     all        all   trust
 # IPV6 local connections
 host     all        all        ::1/128        trust

Reload and configure database scheme.

 #> /etc/init.d/postgresql-8.x reload
 #> cd /path/to/icinga-src/module/idoutils/db/pgsql
 #> psql -U icinga -d icinga < pgsql.sql

Edit the DB config file to customize IDOUtils

 #> vi /usr/local/icinga/etc/ido2db.cfg


Create a database schema and username/password (refer to the Oracle documentation at http://www.oracle.com or consult your DBA). Import the database scheme with sqlplus (or your preferred method). Copy module/idoutils/db/oracle/oracle.sql to $ORACLE_HOME

 #> su - oracle
 $> sqlplus dbuser/dbpass
 SQL> @oracle.sql

Edit the DB config file to customize IDOUtils. Remember that Oracle ignores the db host, instead point db_name to //DBSERVER/DBNAME

 #> vi /usr/local/icinga/etc/ido2db.cfg

Configure the Classic Web Interface

Icinga ships with the classic web interface ("the CGIs") which can be installed via

 #> make cgis
 #> make install-cgis
 #> make install-html

If you are interested in the new Icinga Web, please refer to Install Icinga Web Interface.

Install the Icinga classic web config file in the Apache conf.d directory.

 #> make install-webconf

Create an icingaadmin account for logging into the Icinga classic web interface. Remember the password you assign to this account - you'll need it later.

 #> htpasswd -c /usr/local/icinga/etc/htpasswd.users icingaadmin

To change the password of an existing user or to add a new user, take this command:

 #> htpasswd /usr/local/icinga/etc/htpasswd.users <USERNAME>
[Note] Note

Depending on your distribution/Apache-version you may have to use htpasswd2 instead.

Reload/Restart Apache to make the new settings take effect.


 #> service httpd restart


 #> service apache2 restart


 #> /etc/init.d/apache2 reload

Compile and Install the Nagios Plugins

Extract the Nagios plugins source code tarball.

 #> cd /usr/src 
 #> tar xvzf nagios-plugins-1.4.15.tar.gz 
 #> cd nagios-plugins-1.4.15  

Compile and install the plugins by changing install directory to /usr/local/icinga

 #> ./configure --prefix=/usr/local/icinga \
    --with-cgiurl=/icinga/cgi-bin --with-htmurl=/icinga \
    --with-nagios-user=icinga --with-nagios-group=icinga
 #> make 
 #> make install 

Adjusting the SELinux settings

RHEL and derived distributions like Fedora and CentOS are shipped with activated SELinux (Security Enhanced Linux) running in "enforcing" mode. This may lead to "Internal Server Error" messages when you try to invoke the Icinga-CGIs.

Check if SELinux runs in enforcing mode

 #> getenforce

Set SELinux in "permissive" mode

 #> setenforce 0

To make this change permanent you have to adjust this setting in /etc/selinux/config and restart the system.

Instead of deactivating SELinux or setting it into permissive mode you can use the following commands to run the CGIs in enforcing/targeted mode:

 #> chcon -R -t httpd_sys_script_exec_t /usr/local/icinga/sbin/
 #> chcon -R -t httpd_sys_content_t /usr/local/icinga/share/
 #> chcon -t httpd_sys_script_rw_t /usr/local/icinga/var/rw/icinga.cmd

Start IDOUtils and Icinga

IDOUtils must be started and running before Icinga is started.

Start IDOUtils:


 #> service ido2db start


 #> /etc/init.d/ido2db start

Stop IDOUtils:


 #> service ido2db stop


 #> /etc/init.d/ido2db stop

Verify the sample Icinga configuration files.

 #> /usr/local/icinga/bin/icinga -v /usr/local/icinga/etc/icinga.cfg 

If there are no errors, start Icinga.


 #> service icinga start


 #> /etc/init.d/icinga start

Configure Icinga Startup

Add Icinga to the list of system services and have it automatically start when the system boots (make sure you have installed the init script before).


 #> chkconfig --add icinga chkconfig icinga on


 #> update-rc.d icinga defaults

Login to the Classic Web Interface

You should now be able to access the Icinga classic web interface at the URL below. You'll be prompted for the username ( icingaadmin ) and password you specified earlier.




Click on the "Service Detail" navbar link to see details of what's being monitored on your local machine. It will take a few minutes for Icinga to check all the services associated with your machine.

Other Modifications

Make sure your system's firewall rules are configured to allow access to the web server if you want to access the Icinga classic interface remotely.

 #> iptables -A INPUT -p tcp -m tcp --dport 80 -j ACCEPT

Setting up your mail transfer agent (MTA) like exim, sendmail or postfix to allow Icinga sending notification emails won't be explained here. Please refer to the Nagios-Wiki for more resources.

There are several tweaks for the IDOUtils (former NDOUtils of Nagios) available.

You're Done

Congratulations! You successfully installed Icinga with IDOUtils. Your journey into monitoring has just begun. You'll no doubt want to monitor more than just your local machine, so check out the chapter on "Getting Started" about "Monitoring ..."