2014-05-04 11:25:12 +02:00
# <a id="getting-started"></a> Getting Started
2015-09-25 11:32:34 +02:00
This tutorial is a step-by-step introduction to installing [Icinga 2 ](2-getting-started.md#setting-up-icinga2 )
2015-12-04 15:29:07 +01:00
and [Icinga Web 2 ](2-getting-started.md#setting-up-icingaweb2 ).
2015-09-25 11:32:34 +02:00
It assumes that you are familiar with the operating system you're using to install Icinga 2.
2014-05-23 01:01:06 +02:00
2014-05-04 11:25:12 +02:00
## <a id="setting-up-icinga2"></a> Setting up Icinga 2
2014-05-29 11:58:25 +02:00
First off you will have to install Icinga 2. The preferred way of doing this
2014-07-21 20:22:48 +02:00
is to use the official package repositories depending on which operating system
and distribution you are running.
2014-05-04 11:25:12 +02:00
2014-07-21 20:22:48 +02:00
Distribution | Repository
2014-05-04 11:25:12 +02:00
------------------------|---------------------------
2017-01-10 15:54:22 +01:00
Debian | [Icinga Repository ](http://packages.icinga.com/debian/ ), [debmon ](https://debmon.org/packages/debmon-jessie/icinga2 )
Ubuntu | [Icinga Repository ](http://packages.icinga.com/ubuntu/ ), [Icinga PPA ](https://launchpad.net/~formorer/+archive/ubuntu/icinga )
RHEL/CentOS | [Icinga Repository ](http://packages.icinga.com/epel/ )
openSUSE | [Icinga Repository ](http://packages.icinga.com/openSUSE/ ), [Server Monitoring Repository ](https://build.opensuse.org/package/show/server:monitoring/icinga2 )
SLES | [Icinga Repository ](http://packages.icinga.com/SUSE/ )
2014-07-21 20:22:48 +02:00
Gentoo | [Upstream ](http://packages.gentoo.org/package/net-analyzer/icinga2 )
FreeBSD | [Upstream ](http://www.freshports.org/net-mgmt/icinga2 )
2017-02-07 13:49:22 +01:00
OpenBSD | [Upstream ](http://ports.su/net/icinga/core2,-main )
2014-07-21 20:22:48 +02:00
ArchLinux | [Upstream ](https://aur.archlinux.org/packages/icinga2 )
2017-02-07 13:49:22 +01:00
AlpineLinux | [Upstream ](https://pkgs.alpinelinux.org/package/edge/community/x86_64/icinga2 )
2014-05-04 11:25:12 +02:00
Packages for distributions other than the ones listed above may also be
2014-07-21 20:22:48 +02:00
available. Please contact your distribution packagers.
2014-05-04 11:25:12 +02:00
2015-02-12 10:29:21 +01:00
### <a id="package-repositories"></a> Package Repositories
2014-08-27 16:30:35 +02:00
You need to add the Icinga repository to your package management configuration.
Below is a list with examples for the various distributions.
2017-01-10 15:54:22 +01:00
Debian:
2014-09-04 17:02:30 +02:00
2017-01-10 15:54:22 +01:00
# wget -O - http://packages.icinga.com/icinga.key | apt-key add -
# echo 'deb http://packages.icinga.com/debian icinga-jessie main' >/etc/apt/sources.list.d/icinga.list
2014-08-27 16:30:35 +02:00
# apt-get update
2017-01-10 15:54:22 +01:00
Ubuntu:
2014-09-04 17:02:30 +02:00
2017-01-10 15:54:22 +01:00
# wget -O - http://packages.icinga.com/icinga.key | apt-key add -
# echo 'deb http://packages.icinga.com/ubuntu icinga-xenial main' >/etc/apt/sources.list.d/icinga.list
2014-08-27 16:30:35 +02:00
# apt-get update
2016-03-23 11:16:38 +01:00
RHEL/CentOS 7:
2014-09-04 17:02:30 +02:00
2017-01-10 15:54:22 +01:00
yum install https://packages.icinga.com/epel/7/release/noarch/icinga-rpm-release-7-1.el7.centos.noarch.rpm
2016-03-23 11:16:38 +01:00
RHEL/CentOS 6:
2017-01-10 15:54:22 +01:00
yum install https://packages.icinga.com/epel/6/release/noarch/icinga-rpm-release-6-1.el6.noarch.rpm
2016-03-23 11:16:38 +01:00
RHEL/CentOS 5:
2017-01-10 15:54:22 +01:00
rpm -i http://packages.icinga.com/epel/5/release/noarch/icinga-rpm-release-5-1.el5.centos.noarch.rpm
2015-07-06 11:41:50 +02:00
2016-12-12 08:13:08 +01:00
Fedora 25:
2016-03-23 11:16:38 +01:00
2017-01-10 15:54:22 +01:00
dnf install https://packages.icinga.com/fedora/25/release/noarch/icinga-rpm-release-25-1.fc25.noarch.rpm
2016-03-23 11:16:38 +01:00
2016-12-12 08:13:08 +01:00
Fedora 24:
2016-03-23 11:16:38 +01:00
2017-01-10 15:54:22 +01:00
dnf install https://packages.icinga.com/fedora/24/release/noarch/icinga-rpm-release-24-1.fc24.noarch.rpm
2016-03-23 11:16:38 +01:00
2016-12-12 08:13:08 +01:00
Fedora 23:
2014-09-04 17:02:30 +02:00
2017-01-10 15:54:22 +01:00
dnf install https://packages.icinga.com/fedora/23/release/noarch/icinga-rpm-release-23-1.fc23.noarch.rpm
2014-08-27 16:30:35 +02:00
2015-02-06 15:08:51 +01:00
SLES 11:
2015-02-03 13:23:50 +01:00
2017-01-10 15:54:22 +01:00
# zypper ar http://packages.icinga.com/SUSE/ICINGA-release-11.repo
2015-02-03 13:23:50 +01:00
# zypper ref
SLES 12:
2014-09-04 17:02:30 +02:00
2017-01-10 15:54:22 +01:00
# zypper ar http://packages.icinga.com/SUSE/ICINGA-release.repo
2014-08-27 16:30:35 +02:00
# zypper ref
2015-01-21 08:01:49 +01:00
openSUSE:
2014-09-04 17:02:30 +02:00
2017-01-10 15:54:22 +01:00
# zypper ar http://packages.icinga.com/openSUSE/ICINGA-release.repo
2014-08-27 16:30:35 +02:00
# zypper ref
2016-08-20 14:51:05 +02:00
#### <a id="package-repositories-rhel-epel"></a> RHEL/CentOS EPEL Repository
The packages for RHEL/CentOS depend on other packages which are distributed
as part of the [EPEL repository ](http://fedoraproject.org/wiki/EPEL ).
CentOS 7/6/5:
yum install epel-release
If you are using RHEL you need enable the `optional` repository and then install
the [EPEL rpm package ](http://fedoraproject.org/wiki/EPEL#How_can_I_use_these_extra_packages.3F ).
#### <a id="package-repositories-sles-security"></a> SLES Security Repository
The packages for SLES 11 depend on the `openssl1` package which is distributed
as part of the [SLES 11 Security Module ](https://www.suse.com/communities/conversations/introducing-the-suse-linux-enterprise-11-security-module/ ).
2017-01-09 16:37:59 +01:00
#### <a id="package-sles-sdk"></a> SLES 12 SDK
Icinga 2 requires the `libboost_chrono1_54_0` package from the `SLES 12 SDK` repository. Refer to the SUSE Enterprise
Linux documentation for further information.
2014-08-27 16:30:35 +02:00
### <a id="installing-icinga2"></a> Installing Icinga 2
2014-05-04 11:25:12 +02:00
You can install Icinga 2 by using your distribution's package manager
to install the `icinga2` package.
2014-08-27 16:30:35 +02:00
Debian/Ubuntu:
2014-09-04 17:02:30 +02:00
2014-08-27 16:30:35 +02:00
# apt-get install icinga2
2015-01-26 14:40:27 +01:00
RHEL/CentOS 5/6:
2014-09-04 17:02:30 +02:00
2014-08-27 16:30:35 +02:00
# yum install icinga2
# chkconfig icinga2 on
# service icinga2 start
2015-01-26 14:40:27 +01:00
RHEL/CentOS 7 and Fedora:
2014-05-04 11:25:12 +02:00
2015-01-26 14:40:27 +01:00
# yum install icinga2
2014-08-27 16:30:35 +02:00
# systemctl enable icinga2
# systemctl start icinga2
2015-01-26 14:40:27 +01:00
SLES/openSUSE:
# zypper install icinga2
2015-10-05 13:49:49 +02:00
FreeBSD:
# pkg install icinga2
2014-05-29 15:34:01 +02:00
### <a id="installation-enabled-features"></a> Enabled Features during Installation
The default installation will enable three features required for a basic
Icinga 2 installation:
* `checker` for executing checks
* `notification` for sending notifications
2014-11-02 21:46:02 +01:00
* `mainlog` for writing the `icinga2.log` file
2014-05-29 15:34:01 +02:00
2015-02-06 15:08:51 +01:00
You can verify that by calling `icinga2 feature list`
2016-08-13 15:59:06 +02:00
[CLI command ](11-cli-commands.md#cli-command-feature ) to see which features are
2015-02-06 15:08:51 +01:00
enabled and disabled.
2014-05-29 15:34:01 +02:00
2014-11-02 21:46:02 +01:00
# icinga2 feature list
2016-12-12 08:01:30 +01:00
Disabled features: api command compatlog debuglog gelf graphite icingastatus ido-mysql ido-pgsql influxdb livestatus opentsdb perfdata statusdata syslog
2014-05-29 15:34:01 +02:00
Enabled features: checker mainlog notification
2014-05-04 11:25:12 +02:00
2014-11-02 21:46:02 +01:00
2014-05-04 11:25:12 +02:00
### <a id="installation-paths"></a> Installation Paths
By default Icinga 2 uses the following files and directories:
2016-12-12 11:34:21 +01:00
Path | Description
----------------------------------------------|------------------------------------
/etc/icinga2 | Contains Icinga 2 configuration files.
/usr/lib/systemd/system/icinga2.service | The Icinga 2 Systemd service file on systems using Systemd.
/etc/init.d/icinga2 | The Icinga 2 init script on systems using SysVinit.
/usr/sbin/icinga2 | Shell wrapper for the Icinga 2 binary.
/usr/lib\*/icinga2 | Libraries and the Icinga 2 binary (use `find /usr -type f -name icinga2` to locate the binary path).
/usr/share/doc/icinga2 | Documentation files that come with Icinga 2.
/usr/share/icinga2/include | The Icinga Template Library and plugin command configuration.
/var/run/icinga2 | PID file.
/var/run/icinga2/cmd | Command pipe and Livestatus socket.
/var/cache/icinga2 | status.dat/objects.cache, icinga2.debug files
/var/spool/icinga2 | Used for performance data spool files.
/var/lib/icinga2 | Icinga 2 state file, cluster log, local CA and configuration files (cluster, api).
/var/log/icinga2 | Log file location and compat/ directory for the CompatLogger feature.
2014-05-04 11:25:12 +02:00
2015-10-05 13:49:49 +02:00
FreeBSD uses slightly different paths:
By default Icinga 2 uses the following files and directories:
Path | Description
------------------------------------|------------------------------------
/usr/local/etc/icinga2 | Contains Icinga 2 configuration files.
/usr/local/etc/rc.d/icinga2 | The Icinga 2 init script.
2016-12-12 11:34:21 +01:00
/usr/local/sbin/icinga2 | Shell wrapper for the Icinga 2 binary.
/usr/local/lib/icinga2 | Libraries and the Icinga 2 binary.
2015-10-05 13:49:49 +02:00
/usr/local/share/doc/icinga2 | Documentation files that come with Icinga 2.
/usr/local/share/icinga2/include | The Icinga Template Library and plugin command configuration.
/var/run/icinga2 | PID file.
/var/run/icinga2/cmd | Command pipe and Livestatus socket.
/var/cache/icinga2 | status.dat/objects.cache, icinga2.debug files
/var/spool/icinga2 | Used for performance data spool files.
2016-12-12 11:34:21 +01:00
/var/lib/icinga2 | Icinga 2 state file, cluster log, local CA and configuration files (cluster, api).
2015-10-05 13:49:49 +02:00
/var/log/icinga2 | Log file location and compat/ directory for the CompatLogger feature.
2014-08-27 16:30:35 +02:00
## <a id="setting-up-check-plugins"></a> Setting up Check Plugins
Without plugins Icinga 2 does not know how to check external services. The
[Monitoring Plugins Project ](https://www.monitoring-plugins.org/ ) provides
an extensive set of plugins which can be used with Icinga 2 to check whether
services are working properly.
2016-06-28 17:48:08 +02:00
These plugins are required to make the [example configuration ](4-configuring-icinga-2.md#configuring-icinga2-overview )
work out-of-the-box.
2014-08-27 16:30:35 +02:00
For your convenience here is a list of package names for some of the more
popular operating systems/distributions:
2015-12-09 15:33:31 +01:00
OS/Distribution | Package Name | Repository | Installation Path
-----------------------|--------------------|---------------------------|----------------------------
RHEL/CentOS | nagios-plugins-all | [EPEL ](http://fedoraproject.org/wiki/EPEL ) | /usr/lib/nagios/plugins or /usr/lib64/nagios/plugins
SLES/OpenSUSE | monitoring-plugins | [server:monitoring ](https://build.opensuse.org/project/repositories/server:monitoring ) | /usr/lib/nagios/plugins
Debian/Ubuntu | nagios-plugins | - | /usr/lib/nagios/plugins
FreeBSD | monitoring-plugins | - | /usr/local/libexec/nagios
OS X | nagios-plugins | [MacPorts ](http://www.macports.org ), [Homebrew ](http://brew.sh ) | /opt/local/libexec or /usr/local/sbin
2014-08-27 16:30:35 +02:00
2015-12-18 14:33:55 +01:00
The recommended way of installing these standard plugins is to use your
distribution's package manager.
Debian/Ubuntu:
# apt-get install nagios-plugins
RHEL/CentOS:
# yum install nagios-plugins-all
The packages for RHEL/CentOS depend on other packages which are distributed
as part of the [EPEL repository ](http://fedoraproject.org/wiki/EPEL ). Please
make sure to enable this repository by following
[these instructions ](http://fedoraproject.org/wiki/EPEL#How_can_I_use_these_extra_packages.3F ).
Fedora:
# dnf install nagios-plugins-all
SLES/openSUSE:
# zypper install monitoring-plugins
The packages for SLES/OpenSUSE depend on other packages which are distributed
as part of the [server:monitoring repository ](https://build.opensuse.org/project/repositories/server:monitoring ).
Please make sure to enable this repository beforehand.
FreeBSD:
# pkg install monitoring-plugins
2014-08-27 16:30:35 +02:00
Depending on which directory your plugins are installed into you may need to
2015-06-16 16:01:02 +02:00
update the global `PluginDir` constant in your [Icinga 2 configuration ](4-configuring-icinga-2.md#constants-conf ).
2015-01-26 14:40:27 +01:00
This constant is used by the check command definitions contained in the Icinga Template Library
2015-01-23 14:15:57 +01:00
to determine where to find the plugin binaries.
2014-08-27 16:30:35 +02:00
2015-12-18 14:33:55 +01:00
> **Note**
>
2016-08-13 15:59:06 +02:00
> Please refer to the [service monitoring](5-service-monitoring.md#service-monitoring-plugins) chapter for details about how to integrate
2015-12-18 14:33:55 +01:00
> additional check plugins into your Icinga 2 setup.
2014-08-27 16:30:35 +02:00
2015-01-26 14:40:27 +01:00
## <a id="running-icinga2"></a> Running Icinga 2
### <a id="init-script"></a> Init Script
2015-10-05 13:49:49 +02:00
Icinga 2's init script is installed in `/etc/init.d/icinga2` (`/usr/local/etc/rc.d/icinga2` on FreeBSD) by default:
2015-01-26 14:40:27 +01:00
# /etc/init.d/icinga2
Usage: /etc/init.d/icinga2 {start|stop|restart|reload|checkconfig|status}
The init script supports the following actions:
Command | Description
--------------------|------------------------
start | The `start` action starts the Icinga 2 daemon.
stop | The `stop` action stops the Icinga 2 daemon.
restart | The `restart` action is a shortcut for running the `stop` action followed by `start` .
reload | The `reload` action sends the `HUP` signal to Icinga 2 which causes it to restart. Unlike the `restart` action `reload` does not wait until Icinga 2 has restarted.
checkconfig | The `checkconfig` action checks if the `/etc/icinga2/icinga2.conf` configuration file contains any errors.
status | The `status` action checks if Icinga 2 is running.
By default the Icinga 2 daemon is running as `icinga` user and group
using the init script. Using Debian packages the user and group are set to
`nagios` for historical reasons.
### <a id="systemd-service"></a> systemd Service
Some distributions (e.g. Fedora, openSUSE and RHEL/CentOS 7) use systemd. The
Icinga 2 packages automatically install the necessary systemd unit files.
2015-02-06 15:08:51 +01:00
The Icinga 2 systemd service can be (re-)started, reloaded, stopped and also
queried for its current status.
2015-01-26 14:40:27 +01:00
# systemctl status icinga2
icinga2.service - Icinga host/service/network monitoring system
Loaded: loaded (/usr/lib/systemd/system/icinga2.service; disabled)
Active: active (running) since Mi 2014-07-23 13:39:38 CEST; 15s ago
Process: 21692 ExecStart=/usr/sbin/icinga2 -c ${ICINGA2_CONFIG_FILE} -d -e ${ICINGA2_ERROR_LOG} -u ${ICINGA2_USER} -g ${ICINGA2_GROUP} (code=exited, status=0/SUCCESS)
Process: 21674 ExecStartPre=/usr/sbin/icinga2-prepare-dirs /etc/sysconfig/icinga2 (code=exited, status=0/SUCCESS)
Main PID: 21727 (icinga2)
CGroup: /system.slice/icinga2.service
2015-02-11 14:10:21 +01:00
21727 /usr/sbin/icinga2 -c /etc/icinga2/icinga2.conf -d -e /var/log/icinga2/error.log -u icinga -g icinga --no-stack-rlimit
2015-01-26 14:40:27 +01:00
Jul 23 13:39:38 nbmif icinga2[21692]: [2014-07-23 13:39:38 +0200] information/ConfigItem: Checked 309 Service(s).
Jul 23 13:39:38 nbmif icinga2[21692]: [2014-07-23 13:39:38 +0200] information/ConfigItem: Checked 1 User(s).
Jul 23 13:39:38 nbmif icinga2[21692]: [2014-07-23 13:39:38 +0200] information/ConfigItem: Checked 15 Notification(s).
Jul 23 13:39:38 nbmif icinga2[21692]: [2014-07-23 13:39:38 +0200] information/ConfigItem: Checked 4 ScheduledDowntime(s).
Jul 23 13:39:38 nbmif icinga2[21692]: [2014-07-23 13:39:38 +0200] information/ConfigItem: Checked 1 UserGroup(s).
Jul 23 13:39:38 nbmif icinga2[21692]: [2014-07-23 13:39:38 +0200] information/ConfigItem: Checked 1 IcingaApplication(s).
Jul 23 13:39:38 nbmif icinga2[21692]: [2014-07-23 13:39:38 +0200] information/ConfigItem: Checked 8 Dependency(s).
Jul 23 13:39:38 nbmif systemd[1]: Started Icinga host/service/network monitoring system.
The `systemctl` command supports the following actions:
Command | Description
--------------------|------------------------
start | The `start` action starts the Icinga 2 daemon.
stop | The `stop` action stops the Icinga 2 daemon.
restart | The `restart` action is a shortcut for running the `stop` action followed by `start` .
reload | The `reload` action sends the `HUP` signal to Icinga 2 which causes it to restart. Unlike the `restart` action `reload` does not wait until Icinga 2 has restarted.
status | The `status` action checks if Icinga 2 is running.
enable | The `enable` action enables the service being started at system boot time (similar to `chkconfig` )
Examples:
# systemctl enable icinga2
# systemctl restart icinga2
Job for icinga2.service failed. See 'systemctl status icinga2.service' and 'journalctl -xn' for details.
2015-02-06 15:08:51 +01:00
If you're stuck with configuration errors, you can manually invoke the
2016-08-13 15:59:06 +02:00
[configuration validation ](11-cli-commands.md#config-validation ).
2015-01-26 14:40:27 +01:00
2015-10-05 13:49:49 +02:00
### FreeBSD
On FreeBSD you need to enable icinga2 in your rc.conf
# sysrc icinga2_enable=yes
# service icinga2 restart
2015-03-07 15:52:56 +01:00
## <a id="configuration-syntax-highlighting"></a> Configuration Syntax Highlighting
Icinga 2 ships configuration examples for syntax highlighting using the `vim` and `nano` editors.
2016-04-15 18:09:09 +02:00
The RHEL and SUSE package `icinga2-common` installs these files into `/usr/share/doc/icinga2-common-[x.x.x]/syntax`
(where `[x.x.x]` is the version number, e.g. `2.4.3` or `2.4.4` ). Sources provide these files in `tools/syntax` .
On Debian systems the `icinga2-common` package provides only the Nano configuration file (`/usr/share/nano/icinga2.nanorc`);
to obtain the Vim configuration, please install the extra package `vim-icinga2` . The files are located in `/usr/share/vim/addons` .
2015-03-07 15:52:56 +01:00
### <a id="configuration-syntax-highlighting-vim"></a> Configuration Syntax Highlighting using Vim
2016-06-17 14:16:17 +02:00
Install the package `vim-icinga2` with your distribution's package manager.
2015-03-07 15:52:56 +01:00
2015-04-28 19:14:05 +02:00
Debian/Ubuntu:
2016-02-04 13:13:23 +01:00
$ apt-get install vim-icinga2 vim-addon-manager
$ vim-addon-manager -w install icinga2
2016-06-17 14:16:17 +02:00
Info: installing removed addon 'icinga2' to /var/lib/vim/addons
2016-04-15 18:09:09 +02:00
2015-04-28 19:14:05 +02:00
RHEL/CentOS/Fedora:
2016-04-15 18:09:09 +02:00
2015-04-28 19:14:05 +02:00
$ yum install vim-icinga2
SLES/openSUSE:
2016-04-15 18:09:09 +02:00
2015-04-28 19:14:05 +02:00
$ zypper install vim-icinga2
2015-03-07 15:52:56 +01:00
2016-06-17 14:16:17 +02:00
Ensure that syntax highlighting is enabled e.g. by editing the user's `vimrc`
configuration file:
$ vim ~/.vimrc
syntax on
2015-03-07 15:52:56 +01:00
Test it:
$ vim /etc/icinga2/conf.d/templates.conf
2016-04-15 18:09:09 +02:00
![Vim with syntax highlighting ](images/getting-started/vim-syntax.png "Vim with Icinga 2 syntax highlighting" )
2015-03-07 15:52:56 +01:00
### <a id="configuration-syntax-highlighting-nano"></a> Configuration Syntax Highlighting using Nano
2016-06-17 14:16:17 +02:00
Install the package `nano-icinga2` with your distribution's package manager.
Debian/Ubuntu:
2015-04-28 19:14:05 +02:00
2016-06-17 14:16:17 +02:00
**Note:** The syntax files are installed with the `icinga2-common` package already.
2015-04-28 19:14:05 +02:00
RHEL/CentOS/Fedora:
$ yum install nano-icinga2
SLES/openSUSE:
$ zypper install nano-icinga2
2016-06-17 14:16:17 +02:00
Copy the `/etc/nanorc` sample file to your home directory.
2015-03-07 15:52:56 +01:00
$ cp /etc/nanorc ~/.nanorc
2016-06-17 14:16:17 +02:00
Include the `icinga2.nanorc` file.
2016-02-04 13:13:23 +01:00
$ vim ~/.nanorc
2015-03-07 15:52:56 +01:00
## Icinga 2
2015-04-28 19:14:05 +02:00
include "/usr/share/nano/icinga2.nanorc"
2015-03-07 15:52:56 +01:00
Test it:
$ nano /etc/icinga2/conf.d/templates.conf
2016-04-15 18:09:09 +02:00
![Nano with syntax highlighting ](images/getting-started/nano-syntax.png "Nano with Icinga 2 syntax highlighting" )
2015-03-07 15:52:56 +01:00
2015-12-04 15:29:07 +01:00
## <a id="setting-up-icingaweb2"></a> Setting up Icinga Web 2
2015-01-26 14:40:27 +01:00
Icinga 2 can be used with Icinga Web 2 and a number of other web interfaces.
2015-10-28 21:07:12 +01:00
This chapter explains how to set up Icinga Web 2.
2014-05-04 11:25:12 +02:00
2015-02-06 15:08:51 +01:00
The DB IDO (Database Icinga Data Output) modules for Icinga 2 take care of
exporting all configuration and status information into a database. The IDO
database is used by a number of projects including
[Icinga Web 2 ](2-getting-started.md#setting-up-icingaweb2 ), Icinga Reporting
or Icinga Web 1.x.
2014-11-15 15:10:22 +01:00
2015-01-20 15:15:54 +01:00
There is a separate module for each database backend. At present support for
2014-08-27 16:30:35 +02:00
both MySQL and PostgreSQL is implemented.
2015-01-23 14:15:57 +01:00
### <a id="configuring-db-ido-mysql"></a> Configuring DB IDO MySQL
2014-05-04 11:25:12 +02:00
2014-08-27 16:30:35 +02:00
#### <a id="installing-database-mysql-server"></a> Installing MySQL database server
2014-05-04 11:25:12 +02:00
2014-08-27 16:30:35 +02:00
Debian/Ubuntu:
2014-09-04 17:02:30 +02:00
2014-08-27 16:30:35 +02:00
# apt-get install mysql-server mysql-client
2014-05-04 11:25:12 +02:00
2014-08-27 16:30:35 +02:00
RHEL/CentOS 5/6:
2014-09-04 17:02:30 +02:00
2014-08-27 16:30:35 +02:00
# yum install mysql-server mysql
# chkconfig mysqld on
# service mysqld start
2015-01-26 14:40:27 +01:00
# mysql_secure_installation
2014-05-04 11:25:12 +02:00
2015-01-23 14:15:57 +01:00
RHEL/CentOS 7 and Fedora:
2014-09-04 17:02:30 +02:00
2014-08-27 16:30:35 +02:00
# yum install mariadb-server mariadb
2015-01-22 16:09:28 +01:00
# systemctl enable mariadb
# systemctl start mariadb
2015-01-26 14:40:27 +01:00
# mysql_secure_installation
2014-05-04 11:25:12 +02:00
2014-08-27 16:30:35 +02:00
SUSE:
2014-09-04 17:02:30 +02:00
2014-08-27 16:30:35 +02:00
# zypper install mysql mysql-client
# chkconfig mysqld on
# service mysqld start
2014-05-04 11:25:12 +02:00
2015-10-05 13:49:49 +02:00
FreeBSD:
# pkg install mysql56-server
# sysrc mysql_enable=yes
# service mysql-server restart
# mysql_secure_installation
2015-01-23 14:15:57 +01:00
#### <a id="installing-database-mysql-modules"></a> Installing the IDO modules for MySQL
2014-05-04 11:25:12 +02:00
2015-01-23 14:15:57 +01:00
The next step is to install the `icinga2-ido-mysql` package using your
2014-09-15 17:00:00 +02:00
distribution's package manager.
Debian/Ubuntu:
# apt-get install icinga2-ido-mysql
RHEL/CentOS:
# yum install icinga2-ido-mysql
SUSE:
# zypper install icinga2-ido-mysql
2015-10-05 13:49:49 +02:00
FreeBSD:
On FreeBSD the IDO modules for MySQL are included with the icinga2 package
and located at /usr/local/share/icinga2-ido-mysql/schema/mysql.sql
2014-09-15 17:00:00 +02:00
2014-08-27 16:30:35 +02:00
> **Note**
2014-05-04 11:25:12 +02:00
>
2015-01-25 16:07:43 +01:00
> The Debian/Ubuntu packages provide a database configuration wizard by
> default. You can skip the automated setup and install/upgrade the
> database manually if you prefer that.
2014-05-04 11:25:12 +02:00
#### <a id="setting-up-mysql-db"></a> Setting up the MySQL database
2014-09-15 17:00:00 +02:00
Set up a MySQL database for Icinga 2:
2014-05-04 11:25:12 +02:00
# mysql -u root -p
mysql> CREATE DATABASE icinga;
2016-04-15 18:09:09 +02:00
mysql> GRANT SELECT, INSERT, UPDATE, DELETE, DROP, CREATE VIEW, INDEX, EXECUTE ON icinga.* TO 'icinga'@'localhost' IDENTIFIED BY 'icinga';
mysql> quit
![setting up the database on CentOS 7 ](images/getting-started/mariadb-centos7.png "Setting up the database on CentOS 7" )
2014-05-04 11:25:12 +02:00
After creating the database you can import the Icinga 2 IDO schema using the
following command:
2014-08-17 13:20:39 +02:00
# mysql -u root -p icinga < /usr/share/icinga2-ido-mysql/schema/mysql.sql
2014-05-04 11:25:12 +02:00
2014-08-27 16:30:35 +02:00
2015-01-23 14:15:57 +01:00
#### <a id="enabling-ido-mysql"></a> Enabling the IDO MySQL module
2014-05-04 11:25:12 +02:00
The package provides a new configuration file that is installed in
2015-01-25 16:07:43 +01:00
`/etc/icinga2/features-available/ido-mysql.conf` . You will need to
update the database credentials in this file.
All available attributes are explained in the
2016-08-13 15:59:06 +02:00
[IdoMysqlConnection object ](9-object-types.md#objecttype-idomysqlconnection )
2015-02-06 15:08:51 +01:00
chapter.
2014-05-04 11:25:12 +02:00
2015-02-06 15:08:51 +01:00
You can enable the `ido-mysql` feature configuration file using
`icinga2 feature enable` :
2014-05-04 11:25:12 +02:00
2014-10-14 18:32:15 +02:00
# icinga2 feature enable ido-mysql
2014-05-04 11:25:12 +02:00
Module 'ido-mysql' was enabled.
Make sure to restart Icinga 2 for these changes to take effect.
After enabling the ido-mysql feature you have to restart Icinga 2:
2014-09-04 17:02:30 +02:00
Debian/Ubuntu, RHEL/CentOS 6 and SUSE:
2014-08-27 16:30:35 +02:00
# service icinga2 restart
2014-05-04 11:25:12 +02:00
2015-01-23 14:15:57 +01:00
RHEL/CentOS 7 and Fedora:
2014-09-04 17:02:30 +02:00
2015-01-22 16:09:28 +01:00
# systemctl restart icinga2
2014-05-04 11:25:12 +02:00
2015-10-05 13:49:49 +02:00
FreeBSD:
# service icinga2 restart
2014-06-13 11:17:32 +02:00
### <a id="configuring-db-ido-postgresql"></a> Configuring DB IDO PostgreSQL
2014-05-04 11:25:12 +02:00
2015-01-23 14:15:57 +01:00
#### <a id="installing-database-postgresql-server"></a> Installing PostgreSQL database server
Debian/Ubuntu:
# apt-get install postgresql
RHEL/CentOS 5/6:
# yum install postgresql-server postgresql
# chkconfig postgresql on
# service postgresql start
RHEL/CentOS 7:
# yum install postgresql-server postgresql
2015-12-08 16:04:02 +01:00
# postgresql-setup initdb
2015-01-23 14:15:57 +01:00
# systemctl enable postgresql
# systemctl start postgresql
SUSE:
# zypper install postgresql postgresql-server
# chkconfig postgresql on
# service postgresql start
2015-10-05 13:49:49 +02:00
FreeBSD:
# pkg install postgresql93-server
# sysrc postgresql_enable=yes
# service postgresql start
2015-01-23 14:15:57 +01:00
#### <a id="installing-database-postgresql-modules"></a> Installing the IDO modules for PostgreSQL
The next step is to install the `icinga2-ido-pgsql` package using your
2014-09-15 17:00:00 +02:00
distribution's package manager.
Debian/Ubuntu:
# apt-get install icinga2-ido-pgsql
RHEL/CentOS:
# yum install icinga2-ido-pgsql
SUSE:
# zypper install icinga2-ido-pgsql
2015-10-05 13:49:49 +02:00
FreeBSD:
On FreeBSD the IDO modules for PostgreSQL are included with the icinga2 package
and located at /usr/local/share/icinga2-ido-pgsql/schema/pgsql.sql
2014-08-27 16:30:35 +02:00
> **Note**
>
> Upstream Debian packages provide a database configuration wizard by default.
> You can skip the automated setup and install/upgrade the database manually
> if you prefer that.
2014-05-04 11:25:12 +02:00
#### Setting up the PostgreSQL database
2014-09-15 17:00:00 +02:00
Set up a PostgreSQL database for Icinga 2:
2014-05-04 11:25:12 +02:00
# cd /tmp
2015-11-20 16:07:44 +01:00
# sudo -u postgres psql -c "CREATE ROLE icinga WITH LOGIN PASSWORD 'icinga'"
2014-05-04 11:25:12 +02:00
# sudo -u postgres createdb -O icinga -E UTF8 icinga
# sudo -u postgres createlang plpgsql icinga
2014-05-29 15:14:44 +02:00
> **Note**
>
2015-02-06 15:08:51 +01:00
> When using PostgreSQL 9.x you can omit the `createlang` command.
2015-11-20 16:07:44 +01:00
> Also it is assumed here that your locale is set to utf-8, you may run into
> problems otherwise.
2014-05-29 15:14:44 +02:00
2015-11-20 16:07:44 +01:00
Locate your pg\_hba.conf (Debian: `/etc/postgresql/*/main/pg_hba.conf` ,
2014-05-04 11:25:12 +02:00
RHEL/SUSE: `/var/lib/pgsql/data/pg_hba.conf` ), add the icinga user with md5
authentication method and restart the postgresql server.
# icinga
local icinga icinga md5
host icinga icinga 127.0.0.1/32 md5
host icinga icinga ::1/128 md5
# "local" is for Unix domain socket connections only
local all all ident
# IPv4 local connections:
host all all 127.0.0.1/32 ident
# IPv6 local connections:
host all all ::1/128 ident
2015-09-05 14:08:35 +02:00
# service postgresql restart
2014-05-04 11:25:12 +02:00
2015-02-06 15:08:51 +01:00
After creating the database and permissions you can import the Icinga 2 IDO
schema using the following command:
2014-05-04 11:25:12 +02:00
# export PGPASSWORD=icinga
2014-08-17 13:20:39 +02:00
# psql -U icinga -d icinga < /usr/share/icinga2-ido-pgsql/schema/pgsql.sql
2014-05-04 11:25:12 +02:00
2016-04-15 18:09:09 +02:00
![importing the Icinga 2 IDO schema ](images/getting-started/postgr-import-ido.png "Importing the Icinga 2 IDO schema on Debian Jessie" )
2014-05-04 11:25:12 +02:00
2015-01-23 14:15:57 +01:00
#### <a id="enabling-ido-postgresql"></a> Enabling the IDO PostgreSQL module
2014-05-04 11:25:12 +02:00
The package provides a new configuration file that is installed in
2015-01-25 16:07:43 +01:00
`/etc/icinga2/features-available/ido-pgsql.conf` . You will need to update
the database credentials in this file.
All available attributes are explained in the
2016-08-13 15:59:06 +02:00
[IdoPgsqlConnection object ](9-object-types.md#objecttype-idopgsqlconnection )
2015-02-06 15:08:51 +01:00
chapter.
2014-05-04 11:25:12 +02:00
2015-02-06 15:08:51 +01:00
You can enable the `ido-pgsql` feature configuration file using
`icinga2 feature enable` :
2014-05-04 11:25:12 +02:00
2014-10-14 18:32:15 +02:00
# icinga2 feature enable ido-pgsql
2014-05-04 11:25:12 +02:00
Module 'ido-pgsql' was enabled.
Make sure to restart Icinga 2 for these changes to take effect.
After enabling the ido-pgsql feature you have to restart Icinga 2:
2015-10-05 13:49:49 +02:00
Debian/Ubuntu, RHEL/CentOS 6, SUSE and FreeBSD:
2014-09-04 17:02:30 +02:00
2014-08-27 16:30:35 +02:00
# service icinga2 restart
2014-05-04 11:25:12 +02:00
2015-01-23 14:15:57 +01:00
RHEL/CentOS 7 and Fedora:
2014-09-04 17:02:30 +02:00
2015-01-22 16:09:28 +01:00
# systemctl restart icinga2
2014-09-04 17:02:30 +02:00
2014-05-04 11:25:12 +02:00
2015-01-26 14:40:27 +01:00
### <a id="icinga2-user-interface-webserver"></a> Webserver
Debian/Ubuntu:
# apt-get install apache2
RHEL/CentOS 6:
# yum install httpd
# chkconfig httpd on
# service httpd start
RHEL/CentOS 7/Fedora:
# yum install httpd
# systemctl enable httpd
# systemctl start httpd
SUSE:
# zypper install apache2
# chkconfig on
# service apache2 start
2015-10-05 13:49:49 +02:00
FreeBSD (nginx, but you could also use the apache24 package):
# pkg install nginx php56-gettext php56-ldap php56-openssl php56-mysql php56-pdo_mysql php56-pgsql php56-pdo_pgsql php56-sockets php56-gd pecl-imagick pecl-intl
# sysrc php_fpm_enable=yes
# sysrc nginx_enable=yes
# sed -i '' "s/listen\ =\ 127.0.0.1:9000/listen\ =\ \/var\/run\/php5-fpm.sock/" /usr/local/etc/php-fpm.conf
# sed -i '' "s/;listen.owner/listen.owner/" /usr/local/etc/php-fpm.conf
# sed -i '' "s/;listen.group/listen.group/" /usr/local/etc/php-fpm.conf
# sed -i '' "s/;listen.mode/listen.mode/" /usr/local/etc/php-fpm.conf
# service php-fpm start
# service nginx start
2015-01-26 14:40:27 +01:00
### <a id="icinga2-user-interface-firewall-rules"></a> Firewall Rules
Example:
# iptables -A INPUT -p tcp -m tcp --dport 80 -j ACCEPT
# service iptables save
RHEL/CentOS 7 specific:
# firewall-cmd --add-service=http
# firewall-cmd --permanent --add-service=http
2015-10-05 13:49:49 +02:00
FreeBSD:
Please consult the [FreeBSD Handbook ](https://www.freebsd.org/doc/en_US.ISO8859-1/books/handbook/firewalls.html ) how to configure one of FreeBSD's firewalls.
2015-01-26 14:40:27 +01:00
2014-08-27 19:20:49 +02:00
### <a id="setting-up-external-command-pipe"></a> Setting Up External Command Pipe
Web interfaces and other Icinga addons are able to send commands to
Icinga 2 through the external command pipe.
2015-01-20 15:15:54 +01:00
You can enable the External Command Pipe using the CLI:
2014-08-27 19:20:49 +02:00
2014-10-14 18:32:15 +02:00
# icinga2 feature enable command
2014-08-27 19:20:49 +02:00
After that you will have to restart Icinga 2:
2014-09-04 17:02:30 +02:00
Debian/Ubuntu, RHEL/CentOS 6 and SUSE:
2014-08-27 19:20:49 +02:00
# service icinga2 restart
2015-01-23 14:15:57 +01:00
RHEL/CentOS 7 and Fedora:
2014-09-04 17:02:30 +02:00
2015-01-22 16:09:28 +01:00
# systemctl restart icinga2
2014-09-04 17:02:30 +02:00
2015-10-05 13:49:49 +02:00
FreeBSD:
# service icinga2 restart
2015-02-06 15:08:51 +01:00
By default the command pipe file is owned by the group `icingacmd` with
read/write permissions. Add your webserver's user to the group `icingacmd` to
2014-08-27 19:20:49 +02:00
enable sending commands to Icinga 2 through your web interface:
2014-11-05 18:15:06 +01:00
# usermod -a -G icingacmd www-data
2014-08-27 19:20:49 +02:00
2015-10-05 13:49:49 +02:00
FreeBSD:
On FreeBSD the rw directory is owned by the group `www` . You do not need to add the
user `icinga` to the group `www` .
2015-02-06 15:08:51 +01:00
Debian packages use `nagios` as the default user and group name. Therefore
change `icingacmd` to `nagios` .
The webserver's user is different between distributions so you might have to
change `www-data` to `wwwrun` , `www` , or `apache` .
2014-08-27 19:20:49 +02:00
2016-04-15 18:09:09 +02:00
Change `www-data` to the user you're using to run queries.
2014-08-27 19:20:49 +02:00
2015-02-06 15:08:51 +01:00
You can verify that the user has been successfully added to the `icingacmd`
group using the `id` command:
2015-01-25 16:07:43 +01:00
2015-02-06 15:08:51 +01:00
$ id < your-webserver-user >
2014-08-27 19:20:49 +02:00
2016-04-15 18:09:09 +02:00
![id command on CentOS 7](images/getting-started/id-apache-centos7.png "Confirm that the webserver's user
(here: `apache` on a CentOS 7 system) is a member of the group `icingacmd` .")
2015-01-23 14:15:57 +01:00
2015-12-04 15:29:07 +01:00
### <a id="installing-icingaweb2"></a> Installing Icinga Web 2
2015-01-23 14:15:57 +01:00
2016-04-01 10:06:26 +02:00
Please consult the [installation documentation ](https://github.com/Icinga/icingaweb2/blob/master/doc/02-Installation.md )
2015-02-06 15:08:51 +01:00
for further instructions on how to install Icinga Web 2.
2015-01-23 14:15:57 +01:00
2015-01-26 14:40:27 +01:00
## <a id="install-addons"></a> Addons
2015-01-23 14:15:57 +01:00
2015-02-06 15:08:51 +01:00
A number of additional features are available in the form of addons. A list of
popular addons is available in the
2016-08-13 15:59:06 +02:00
[Addons and Plugins ](13-addons.md#addons ) chapter.
## <a id="install-backup"></a> Backup
Ensure to include the following in your backups:
* Configuration files in `/etc/icinga2`
* Runtime files in `/var/lib/icinga2` (the master's CA is stored here as well)
* Optional: IDO database backup