2014-11-18 16:56:39 +01:00
# <a id="installation"></a> Installation
2013-07-03 14:00:55 +02:00
2014-11-18 16:56:39 +01:00
The preferred way of installing Icinga Web 2 is to use the official package repositories depending on which operating
2014-11-18 16:58:08 +01:00
system and distribution you are running. But it is also possible to install Icinga Web 2 directly from source.
2013-07-03 14:00:55 +02:00
2015-09-27 17:32:24 +02:00
In case you are upgrading from an older version of Icinga Web 2
2016-04-13 13:43:39 +02:00
please make sure to read the [upgrading ](02-Installation.md#upgrading ) section
2015-10-02 10:36:39 +02:00
thoroughly.
2015-09-27 17:32:24 +02:00
2015-04-16 13:59:17 +02:00
## <a id="installing-requirements"></a> Installing Requirements
2013-10-20 14:51:03 +02:00
2014-11-18 16:56:39 +01:00
* A web server, e.g. Apache or nginx
2015-04-16 13:59:17 +02:00
* PHP >= 5.3.0 w/ gettext, intl and OpenSSL support
2016-12-11 17:24:04 +01:00
* Default time zone configured for PHP in the php.ini file
2014-11-18 16:56:39 +01:00
* LDAP PHP library when using Active Directory or LDAP for authentication
2016-02-17 15:26:52 +01:00
* Icinga 1.x w/ IDO; Icinga 2.x w/ IDO feature enabled
* The IDO table prefix must be icinga_ which is the default
* MySQL or PostgreSQL PHP libraries
2016-10-13 12:07:36 +02:00
* cURL PHP library when using the Icinga 2 API for transmitting external commands
2013-10-20 14:51:03 +02:00
2016-02-16 00:25:35 +01:00
### <a id="pagespeed-incompatibility"></a> PageSpeed Module Incompatibility
It seems that Web 2 is not compatible with the PageSpeed module. Please disable the PageSpeed module using one of the
following methods.
**Apache**:
2016-02-17 15:26:52 +01:00
```
2016-02-16 00:25:35 +01:00
ModPagespeedDisallow "*/icingaweb2/*"
2016-02-17 15:26:52 +01:00
```
2016-02-16 00:25:35 +01:00
**Nginx**:
2016-02-17 15:26:52 +01:00
```
2016-02-16 00:25:35 +01:00
pagespeed Disallow "*/icingaweb2/*";
2016-02-17 15:26:52 +01:00
```
2016-02-16 00:25:35 +01:00
2015-04-16 13:59:17 +02:00
## <a id="installing-from-package"></a> Installing Icinga Web 2 from Package
2013-10-20 14:51:03 +02:00
2015-04-16 13:59:17 +02:00
Below is a list of official package repositories for installing Icinga Web 2 for various operating systems.
2013-07-03 14:00:55 +02:00
2016-09-01 14:18:29 +02:00
| Distribution | Repository |
| ------------- | ---------- |
2016-09-05 11:00:53 +02:00
| Debian | [Icinga Repository ](http://packages.icinga.org/debian/ ) |
2016-09-01 14:18:29 +02:00
| Ubuntu | [Icinga Repository ](http://packages.icinga.org/ubuntu/ ) |
| RHEL/CentOS | [Icinga Repository ](http://packages.icinga.org/epel/ ) |
| openSUSE | [Icinga Repository ](http://packages.icinga.org/openSUSE/ ) |
| SLES | [Icinga Repository ](http://packages.icinga.org/SUSE/ ) |
2016-09-05 11:26:19 +02:00
| Gentoo | [Upstream ](https://packages.gentoo.org/packages/www-apps/icingaweb2 ) |
| FreeBSD | [Upstream ](http://portsmon.freebsd.org/portoverview.py?category=net-mgmt&portname=icingaweb2 ) |
2016-09-01 14:18:29 +02:00
| ArchLinux | [Upstream ](https://aur.archlinux.org/packages/icingaweb2 ) |
2013-07-03 14:00:55 +02:00
2015-04-16 13:59:17 +02:00
Packages for distributions other than the ones listed above may also be available.
Please contact your distribution packagers.
### <a id="package-repositories"></a> Setting up Package Repositories
You need to add the Icinga repository to your package management configuration for installing Icinga Web 2.
2016-09-05 11:00:53 +02:00
If you've already configured your OS to use the Icinga repository for installing Icinga 2, you may skip this step.
Below is a list with **examples** for various distributions.
2015-04-16 13:59:17 +02:00
2016-09-05 11:00:53 +02:00
**Debian Jessie**:
2016-02-17 15:26:52 +01:00
```
2016-09-05 11:00:53 +02:00
wget -O - http://packages.icinga.org/icinga.key | apt-key add -
echo 'deb http://packages.icinga.org/debian icinga-jessie main' >/etc/apt/sources.list.d/icinga.list
2015-04-16 13:59:17 +02:00
apt-get update
2016-02-17 15:26:52 +01:00
```
2015-04-16 13:59:17 +02:00
2016-09-05 11:00:53 +02:00
> INFO
>
> For other Debian versions just replace jessie with your distribution's code name.
**Ubuntu Xenial**:
2016-02-17 15:26:52 +01:00
```
2015-04-16 13:59:17 +02:00
wget -O - http://packages.icinga.org/icinga.key | apt-key add -
2016-09-05 11:00:53 +02:00
add-apt-repository 'deb http://packages.icinga.org/ubuntu icinga-xenial main'
2015-04-16 13:59:17 +02:00
apt-get update
2016-02-17 15:26:52 +01:00
```
2016-09-05 11:00:53 +02:00
> INFO
>
> For other Ubuntu versions just replace xenial with your distribution's code name.
2015-04-16 13:59:17 +02:00
2015-07-01 12:56:04 +02:00
**RHEL and CentOS**:
2016-02-17 15:26:52 +01:00
```
2015-04-16 13:59:17 +02:00
rpm --import http://packages.icinga.org/icinga.key
curl -o /etc/yum.repos.d/ICINGA-release.repo http://packages.icinga.org/epel/ICINGA-release.repo
yum makecache
2016-02-17 15:26:52 +01:00
```
2015-04-16 13:59:17 +02:00
2015-07-01 12:56:04 +02:00
**Fedora**:
2016-02-17 15:26:52 +01:00
```
2015-04-16 13:59:17 +02:00
rpm --import http://packages.icinga.org/icinga.key
curl -o /etc/yum.repos.d/ICINGA-release.repo http://packages.icinga.org/fedora/ICINGA-release.repo
yum makecache
2016-02-17 15:26:52 +01:00
```
2015-04-16 13:59:17 +02:00
2015-07-01 12:56:04 +02:00
**SLES 11**:
2016-02-17 15:26:52 +01:00
```
2015-04-16 13:59:17 +02:00
zypper ar http://packages.icinga.org/SUSE/ICINGA-release-11.repo
zypper ref
2016-02-17 15:26:52 +01:00
```
2015-04-16 13:59:17 +02:00
2015-07-01 12:56:04 +02:00
**SLES 12**:
2016-02-17 15:26:52 +01:00
```
2015-04-16 13:59:17 +02:00
zypper ar http://packages.icinga.org/SUSE/ICINGA-release.repo
zypper ref
2016-02-17 15:26:52 +01:00
```
2015-04-16 13:59:17 +02:00
2015-07-01 12:56:04 +02:00
**openSUSE**:
2016-02-17 15:26:52 +01:00
```
2015-04-16 13:59:17 +02:00
zypper ar http://packages.icinga.org/openSUSE/ICINGA-release.repo
zypper ref
2016-02-17 15:26:52 +01:00
```
2015-04-16 13:59:17 +02:00
2015-07-01 12:56:04 +02:00
#### <a id="package-repositories-rhel-notes"></a> RHEL/CentOS Notes
2015-04-16 13:59:17 +02:00
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 ).
2016-09-01 14:31:39 +02:00
> Please note that installing Icinga Web 2 on **RHEL/CentOS 5** is not supported due to EOL versions of PHP and PostgreSQL.
2015-07-02 11:42:58 +02:00
2015-04-16 13:59:17 +02:00
### <a id="installing-from-package-example"></a> Installing Icinga Web 2
You can install Icinga Web 2 by using your distribution's package manager to install the `icingaweb2` package.
2015-07-24 09:44:53 +02:00
Below is a list with examples for various distributions. The additional package `icingacli` is necessary on RPM based systems for being able to follow further steps in this guide. In DEB based systems, the icingacli binary is included in the icingaweb2 package.
2015-04-16 13:59:17 +02:00
2015-07-01 12:56:04 +02:00
**Debian and Ubuntu**:
2016-02-17 15:26:52 +01:00
```
2015-07-24 09:44:53 +02:00
apt-get install icingaweb2
2016-02-17 15:26:52 +01:00
```
2015-04-16 13:59:17 +02:00
2015-07-01 12:56:04 +02:00
**RHEL, CentOS and Fedora**:
2016-02-17 15:26:52 +01:00
```
2015-06-22 12:03:56 +02:00
yum install icingaweb2 icingacli
2016-02-17 15:26:52 +01:00
```
2015-07-01 12:56:04 +02:00
For RHEL/CentOS please read the [package repositories notes ](#package-repositories-rhel-notes ).
2015-04-16 13:59:17 +02:00
2015-07-01 12:56:04 +02:00
**SLES and openSUSE**:
2016-02-17 15:26:52 +01:00
```
2015-06-22 12:03:56 +02:00
zypper install icingaweb2 icingacli
2016-02-17 15:26:52 +01:00
```
2015-04-16 13:59:17 +02:00
### <a id="preparing-web-setup-from-package"></a> Preparing Web Setup
You can set up Icinga Web 2 quickly and easily with the Icinga Web 2 setup wizard which is available the first time
you visit Icinga Web 2 in your browser. When using the web setup you are required to authenticate using a token.
In order to generate a token use the `icingacli` :
2016-02-17 15:26:52 +01:00
```
2015-04-16 13:59:17 +02:00
icingacli setup token create
2016-02-17 15:26:52 +01:00
```
2015-04-16 13:59:17 +02:00
In case you do not remember the token you can show it using the `icingacli` :
2016-02-17 15:26:52 +01:00
```
2015-04-16 13:59:17 +02:00
icingacli setup token show
2016-02-17 15:26:52 +01:00
```
2015-04-16 13:59:17 +02:00
Finally visit Icinga Web 2 in your browser to access the setup wizard and complete the installation:
`/icingaweb2/setup` .
## <a id="installing-from-source"></a> Installing Icinga Web 2 from Source
Although the preferred way of installing Icinga Web 2 is to use packages, it is also possible to install Icinga Web 2
directly from source.
### <a id="getting-the-source"></a> Getting the Source
2013-07-03 14:00:55 +02:00
2014-11-18 16:56:39 +01:00
First of all, you need to download the sources. Icinga Web 2 is available through a Git repository. You can clone this
repository either via git or http protocol using the following URLs:
2013-07-03 14:00:55 +02:00
2014-11-18 16:56:39 +01:00
* git://git.icinga.org/icingaweb2.git
* http://git.icinga.org/icingaweb2.git
2013-07-03 14:00:55 +02:00
2014-11-18 16:56:39 +01:00
There is also a browsable version available at
2014-12-24 17:30:30 +01:00
[git.icinga.org ](https://git.icinga.org/?p=icingaweb2.git;a=summary "Icinga Web 2 Git Repository" ).
2014-11-18 16:56:39 +01:00
This version also offers snapshots for easy download which you can use if you do not have git present on your system.
2013-07-03 14:00:55 +02:00
2016-02-17 15:26:52 +01:00
```
2014-11-18 16:56:39 +01:00
git clone git://git.icinga.org/icingaweb2.git
2016-02-17 15:26:52 +01:00
```
2013-08-29 10:55:12 +02:00
2015-09-29 19:50:08 +02:00
### <a id="installing-from-source-requirements"></a> Installing Requirements from Source
2016-04-13 13:43:39 +02:00
You will need to install certain dependencies depending on your setup listed [here ](02-Installation.md#installing-requirements ).
2015-09-29 19:50:08 +02:00
The following example installs Apache2 as web server, MySQL as RDBMS and uses the PHP adapter for MySQL.
Adopt the package requirements to your needs (e.g. adding ldap for authentication) and distribution.
Example for RHEL/CentOS/Fedora:
2015-11-13 09:33:32 +01:00
```
yum install httpd mysql-server
yum install php php-gd php-intl php-ZendFramework php-ZendFramework-Db-Adapter-Pdo-Mysql
```
2015-09-29 19:50:08 +02:00
The setup wizard will check the pre-requisites later on.
2015-04-16 13:59:17 +02:00
### <a id="installing-from-source-example"></a> Installing Icinga Web 2
2013-08-29 10:55:12 +02:00
2014-11-18 16:56:39 +01:00
Choose a target directory and move Icinga Web 2 there.
2013-07-03 14:00:55 +02:00
2016-02-17 15:26:52 +01:00
```
2015-01-13 13:08:09 +01:00
mv icingaweb2 /usr/share/icingaweb2
2016-02-17 15:26:52 +01:00
```
2013-07-03 14:00:55 +02:00
2015-04-16 13:59:17 +02:00
### <a id="configuring-web-server"></a> Configuring the Web Server
2013-07-03 14:00:55 +02:00
2014-11-18 16:56:39 +01:00
Use `icingacli` to generate web server configuration for either Apache or nginx.
2013-07-03 14:00:55 +02:00
2015-07-01 12:56:04 +02:00
**Apache**:
2016-02-17 15:26:52 +01:00
```
2015-01-13 13:08:09 +01:00
./bin/icingacli setup config webserver apache --document-root /usr/share/icingaweb2/public
2016-02-17 15:26:52 +01:00
```
2013-07-26 12:58:21 +02:00
2015-07-01 12:56:04 +02:00
**nginx**:
2016-02-17 15:26:52 +01:00
```
2015-01-13 13:08:09 +01:00
./bin/icingacli setup config webserver nginx --document-root /usr/share/icingaweb2/public
2016-02-17 15:26:52 +01:00
```
2013-07-26 12:58:21 +02:00
2015-02-07 21:15:26 +01:00
Save the output as new file in your webserver's configuration directory.
2015-04-16 13:59:17 +02:00
Example for Apache on RHEL or CentOS:
2016-02-17 15:26:52 +01:00
```
2015-02-07 21:15:26 +01:00
./bin/icingacli setup config webserver apache --document-root /usr/share/icingaweb2/public > /etc/httpd/conf.d/icingaweb2.conf
2016-02-17 15:26:52 +01:00
```
2015-02-07 21:15:26 +01:00
2015-10-02 10:36:39 +02:00
Example for Apache on SUSE:
2016-02-17 15:26:52 +01:00
```
2015-10-02 10:36:39 +02:00
./bin/icingacli setup config webserver apache --document-root /usr/share/icingaweb2/public > /etc/apache2/conf.d/icingaweb2.conf
2016-02-17 15:26:52 +01:00
```
2015-10-02 10:36:39 +02:00
2015-09-29 19:50:08 +02:00
Example for Apache on Debian Jessie:
2016-02-17 15:26:52 +01:00
```
2015-09-29 19:50:08 +02:00
./bin/icingacli setup config webserver apache --document-root /usr/share/icingaweb2/public > /etc/apache2/conf-available/icingaweb2.conf
a2enconf icingaweb2
2016-02-17 15:26:52 +01:00
```
2015-09-29 19:50:08 +02:00
### <a id="preparing-web-setup-from-source"></a> Preparing Icinga Web 2 Setup
2015-02-07 21:15:26 +01:00
2015-04-16 13:59:17 +02:00
You can set up Icinga Web 2 quickly and easily with the Icinga Web 2 setup wizard which is available the first time
you visit Icinga Web 2 in your browser. Please follow the steps listed below for preparing the web setup.
2015-01-14 13:24:04 +01:00
Because both web and CLI must have access to configuration and logs, permissions will be managed using a special
system group. The web server user and CLI user have to be added to this system group.
Add the system group `icingaweb2` in the first place.
2015-07-01 12:56:04 +02:00
**Fedora, RHEL, CentOS, SLES and OpenSUSE**:
2016-02-17 15:26:52 +01:00
```
2015-01-14 13:24:04 +01:00
groupadd -r icingaweb2
2016-02-17 15:26:52 +01:00
```
2015-01-14 13:24:04 +01:00
2015-07-01 12:56:04 +02:00
**Debian and Ubuntu**:
2016-02-17 15:26:52 +01:00
```
2015-01-14 13:24:04 +01:00
addgroup --system icingaweb2
2016-02-17 15:26:52 +01:00
```
2015-01-14 13:24:04 +01:00
2015-09-27 17:12:24 +02:00
Add your web server's user to the system group `icingaweb2`
and restart the web server:
2015-01-14 13:24:04 +01:00
2015-07-01 12:56:04 +02:00
**Fedora, RHEL and CentOS**:
2016-02-17 15:26:52 +01:00
```
2015-01-14 13:24:04 +01:00
usermod -a -G icingaweb2 apache
2015-09-27 17:12:24 +02:00
service httpd restart
2016-02-17 15:26:52 +01:00
```
2015-01-14 13:24:04 +01:00
2015-07-01 12:56:04 +02:00
**SLES and OpenSUSE**:
2016-02-17 15:26:52 +01:00
```
2015-02-04 17:23:07 +01:00
usermod -A icingaweb2 wwwrun
2015-09-27 17:12:24 +02:00
service apache2 restart
2016-02-17 15:26:52 +01:00
```
2015-01-14 13:24:04 +01:00
2015-07-01 12:56:04 +02:00
**Debian and Ubuntu**:
2016-02-17 15:26:52 +01:00
```
2015-02-04 23:50:58 +01:00
usermod -a -G icingaweb2 www-data
2015-09-27 17:12:24 +02:00
service apache2 restart
2016-02-17 15:26:52 +01:00
```
2015-01-14 13:24:04 +01:00
2015-09-27 17:12:24 +02:00
2015-01-14 13:24:04 +01:00
Use `icingacli` to create the configuration directory which defaults to ** /etc/icingaweb2**:
2016-02-17 15:26:52 +01:00
```
2015-01-14 13:24:04 +01:00
./bin/icingacli setup config directory
2016-02-17 15:26:52 +01:00
```
2015-01-14 13:24:04 +01:00
2015-04-16 13:59:17 +02:00
2015-01-14 13:24:04 +01:00
When using the web setup you are required to authenticate using a token. In order to generate a token use the
`icingacli` :
2016-02-17 15:26:52 +01:00
```
2015-01-14 13:24:04 +01:00
./bin/icingacli setup token create
2016-02-17 15:26:52 +01:00
```
2015-01-14 13:24:04 +01:00
In case you do not remember the token you can show it using the `icingacli` :
2016-02-17 15:26:52 +01:00
```
2015-01-14 13:24:04 +01:00
./bin/icingacli setup token show
2016-02-17 15:26:52 +01:00
```
2015-01-14 13:24:04 +01:00
2015-09-29 19:50:08 +02:00
### <a id="web-setup-from-source-wizard"></a> Icinga Web 2 Setup Wizard
2015-04-16 13:59:17 +02:00
Finally visit Icinga Web 2 in your browser to access the setup wizard and complete the installation:
`/icingaweb2/setup` .
2015-02-03 16:52:36 +01:00
2015-10-02 10:36:39 +02:00
Paste the previously generated token and follow the steps on-screen. Then you are done here.
2015-09-29 19:50:08 +02:00
### <a id="web-setup-manual-from-source"></a> Icinga Web 2 Manual Setup
If you have chosen not to run the setup wizard, you will need further knowledge
about
* manual creation of the Icinga Web 2 database `icingaweb2` including a default user (optional as authentication and session backend)
* additional configuration for the application
* additional configuration for the monitoring module (e.g. the IDO database and external command pipe from Icinga 2)
This comes in handy if you are planning to deploy Icinga Web 2 automatically using
Puppet, Ansible, Chef, etc. modules.
> **Warning**
>
> Read the documentation on the respective linked configuration sections before
> deploying the configuration manually.
>
2016-04-13 13:43:39 +02:00
> If you are unsure about certain settings, use the [setup wizard](02-Installation.md#web-setup-wizard-from-source) once
2015-09-29 19:50:08 +02:00
> and then collect the generated configuration as well as sql dumps.
#### <a id="web-setup-manual-from-source-database"></a> Icinga Web 2 Manual Database Setup
Create the database and add a new user as shown below for MySQL:
2016-02-17 15:26:52 +01:00
```
2015-11-13 09:33:32 +01:00
sudo mysql -p
2015-09-29 19:50:08 +02:00
CREATE DATABASE icingaweb2;
GRANT SELECT, INSERT, UPDATE, DELETE, DROP, CREATE VIEW, INDEX, EXECUTE ON icingaweb2.* TO 'icingaweb2'@'localhost' IDENTIFIED BY 'icingaweb2';
quit
2015-11-13 09:33:32 +01:00
mysql -p icingaweb2 < /usr/share/icingaweb2/etc/schema/mysql.schema.sql
2016-02-17 15:26:52 +01:00
```
2015-09-29 19:50:08 +02:00
2016-04-13 13:43:39 +02:00
Then generate a new password hash as described in the [authentication docs ](05-Authentication.md#authentication-configuration-db-setup )
2015-09-29 19:50:08 +02:00
and use it to insert a new user called `icingaadmin` into the database.
2016-02-17 15:26:52 +01:00
```
2015-11-13 09:33:32 +01:00
mysql -p icingaweb2
2015-09-29 19:50:08 +02:00
INSERT INTO icingaweb_user (name, active, password_hash) VALUES ('icingaadmin', 1, '$1$EzxLOFDr$giVx3bGhVm4lDUAw6srGX1');
quit
2016-02-17 15:26:52 +01:00
```
2015-09-29 19:50:08 +02:00
#### <a id="web-setup-manual-from-source-config"></a> Icinga Web 2 Manual Configuration
2016-04-13 13:43:39 +02:00
[resources.ini ](04-Resources.md#resources ) providing the details for the Icinga Web 2 and
2015-09-29 19:50:08 +02:00
Icinga 2 IDO database configuration. Example for MySQL:
2016-02-17 15:26:52 +01:00
```
2015-09-29 19:50:08 +02:00
vim /etc/icingaweb2/resources.ini
[icingaweb2]
type = "db"
db = "mysql"
host = "localhost"
port = "3306"
dbname = "icingaweb2"
username = "icingaweb2"
password = "icingaweb2"
[icinga2]
type = "db"
db = "mysql"
host = "localhost"
port = "3306"
dbname = "icinga"
username = "icinga"
password = "icinga"
2016-02-17 15:26:52 +01:00
```
2015-09-29 19:50:08 +02:00
2016-04-13 13:43:39 +02:00
[config.ini ](03-Configuration.md#configuration ) defining general application settings.
2015-09-29 19:50:08 +02:00
2016-02-17 15:26:52 +01:00
```
2015-09-29 19:50:08 +02:00
vim /etc/icingaweb2/config.ini
[logging]
log = "syslog"
level = "ERROR"
application = "icingaweb2"
[preferences]
type = "db"
resource = "icingaweb2"
2016-02-17 15:26:52 +01:00
```
2015-09-29 19:50:08 +02:00
2016-04-13 13:43:39 +02:00
[authentication.ini ](05-Authentication.md#authentication ) for e.g. using the previously created database.
2015-09-29 19:50:08 +02:00
2016-02-17 15:26:52 +01:00
```
2015-09-29 19:50:08 +02:00
vim /etc/icingaweb2/authentication.ini
[icingaweb2]
backend = "db"
resource = "icingaweb2"
2016-02-17 15:26:52 +01:00
```
2015-09-29 19:50:08 +02:00
2016-04-13 13:43:39 +02:00
[roles.ini ](06-Security.md#security ) granting the previously added `icingaadmin` user all permissions.
2015-09-29 19:50:08 +02:00
2016-02-17 15:26:52 +01:00
```
2015-09-29 19:50:08 +02:00
vim /etc/icingaweb2/roles.ini
[admins]
users = "icingaadmin"
permissions = "*"
2016-02-17 15:26:52 +01:00
```
2015-09-29 19:50:08 +02:00
#### <a id="web-setup-manual-from-source-config-monitoring-module"></a> Icinga Web 2 Manual Configuration Monitoring Module
2016-04-13 13:43:39 +02:00
**config.ini** defining additional security settings.
2015-09-29 19:50:08 +02:00
2016-02-17 15:26:52 +01:00
```
2015-09-29 19:50:08 +02:00
vim /etc/icingaweb2/modules/monitoring/config.ini
[security]
protected_customvars = "*pw*,*pass*,community"
2016-02-17 15:26:52 +01:00
```
2015-09-29 19:50:08 +02:00
2016-04-13 13:43:39 +02:00
**backends.ini** referencing the Icinga 2 DB IDO resource.
2015-09-29 19:50:08 +02:00
2016-02-17 15:26:52 +01:00
```
2015-09-29 19:50:08 +02:00
vim /etc/icingaweb2/modules/monitoring/backends.ini
[icinga2]
type = "ido"
resource = "icinga2"
2016-02-17 15:26:52 +01:00
```
2015-09-29 19:50:08 +02:00
2016-04-13 13:43:39 +02:00
**commandtransports.ini** defining the Icinga command pipe.
2015-09-29 19:50:08 +02:00
2016-02-17 15:26:52 +01:00
```
2015-09-29 19:50:08 +02:00
vim /etc/icingaweb2/modules/monitoring/commandtransports.ini
[icinga2]
transport = "local"
path = "/var/run/icinga2/cmd/icinga2.cmd"
2016-02-17 15:26:52 +01:00
```
2015-09-29 19:50:08 +02:00
#### <a id="web-setup-manual-from-source-login"></a> Icinga Web 2 Manual Setup Login
Finally visit Icinga Web 2 in your browser to login as `icingaadmin` user: `/icingaweb2` .
2016-07-08 16:39:24 +02:00
## <a id="upgrading"></a> Upgrading Icinga Web 2
2015-09-27 17:32:24 +02:00
2016-07-08 16:39:24 +02:00
### <a id="upgrading-to-2.3.x"></a> Upgrading to Icinga Web 2 2.3.x
2015-06-18 15:48:23 +02:00
2016-04-18 01:13:04 +02:00
* Icinga Web 2 version 2.3.x does not introduce any backward incompatible change.
2015-06-18 15:48:23 +02:00
2016-07-08 16:39:24 +02:00
### <a id="upgrading-to-2.2.0"></a> Upgrading to Icinga Web 2 2.2.0
2015-08-27 15:34:09 +02:00
2016-04-13 13:47:11 +02:00
* The menu entry `Authorization` beneath `Config` has been renamed to `Authentication` . The role, user backend and user
group backend configuration which was previously found beneath `Authentication` has been moved to `Application` .
2016-07-08 16:39:24 +02:00
### <a id="upgrading-to-2.1.x"></a> Upgrading to Icinga Web 2 2.1.x
2015-08-27 15:34:09 +02:00
2016-04-13 13:47:11 +02:00
* Since Icinga Web 2 version 2.1.3 LDAP user group backends respect the configuration option `group_filter` .
Users who changed the configuration manually and used the option `filter` instead
have to change it back to `group_filter` .
2015-06-18 15:48:23 +02:00
2016-07-08 16:39:24 +02:00
### <a id="upgrading-to-2.0.0"></a> Upgrading to Icinga Web 2 2.0.0
2015-07-02 09:51:43 +02:00
* Icinga Web 2 installations from package on RHEL/CentOS 7 now depend on `php-ZendFramework` which is available through
2015-08-27 15:34:09 +02:00
the [EPEL repository ](http://fedoraproject.org/wiki/EPEL ). Before, Zend was installed as Icinga Web 2 vendor library
through the package `icingaweb2-vendor-zend` . After upgrading, please make sure to remove the package
`icingaweb2-vendor-zend` .
2015-07-27 11:30:44 +02:00
* Icinga Web 2 version 2.0.0 requires permissions for accessing modules. Those permissions are automatically generated
2015-08-27 15:34:09 +02:00
for each installed module in the format `module/<moduleName>` . Administrators have to grant the module permissions to
users and/or user groups in the roles configuration for permitting access to specific modules.
In addition, restrictions provided by modules are now configurable for each installed module too. Before,
a module had to be enabled before having the possibility to configure restrictions.
* The **instances.ini** configuration file provided by the monitoring module
has been renamed to **commandtransports.ini** . The content and location of
the file remains unchanged.
2015-09-07 11:20:36 +02:00
* The location of a user's preferences has been changed from
2015-10-09 11:50:05 +02:00
** < config-dir> /preferences/< username> .ini** to
** < config-dir> /preferences/< username> /config.ini**.
2015-09-15 13:31:30 +02:00
The content of the file remains unchanged.
2015-11-16 15:38:10 +01:00
2016-07-08 16:39:24 +02:00
### <a id="upgrading-to-rc1"></a> Upgrading to Icinga Web 2 Release Candidate 1
2015-11-16 15:38:10 +01:00
2016-04-13 13:47:11 +02:00
The first release candidate of Icinga Web 2 introduces the following non-backward compatible changes:
2016-02-27 15:27:59 +01:00
2016-04-13 13:47:11 +02:00
* The database schema has been adjusted and the tables `icingaweb_group` and
`icingaweb_group_membership` were altered to ensure referential integrity.
Please use the upgrade script located in **etc/schema/** to update your
database schema
2016-02-27 15:27:59 +01:00
2016-04-13 13:47:11 +02:00
* Users who are using PostgreSQL < v9.1 are required to upgrade their
environment to v9.1+ as this is the new minimum required version
for utilizing PostgreSQL as database backend
* The restrictions `monitoring/hosts/filter` and `monitoring/services/filter`
provided by the monitoring module were merged together. The new
restriction is called `monitoring/filter/objects` and supports only a
predefined subset of filter columns. Please see the module's security
related documentation for more details.
2016-07-08 16:39:24 +02:00
### <a id="upgrading-to-beta3"></a> Upgrading to Icinga Web 2 Beta 3
2016-04-13 13:47:11 +02:00
Because Icinga Web 2 Beta 3 does not introduce any backward incompatible change you don't have to change your
configuration files after upgrading to Icinga Web 2 Beta 3.
2016-07-08 16:39:24 +02:00
### <a id="upgrading-to-beta2"></a> Upgrading to Icinga Web 2 Beta 2
2016-04-13 13:47:11 +02:00
Icinga Web 2 Beta 2 introduces access control based on roles for secured actions. If you've already set up Icinga Web 2,
you are required to create the file **roles.ini** beneath Icinga Web 2's configuration directory with the following
content:
```
[administrators]
users = "your_user_name, another_user_name"
permissions = "*"
```
After please log out from Icinga Web 2 and log in again for having all permissions granted.
If you delegated authentication to your web server using the `autologin` backend, you have to switch to the `external`
2016-07-08 16:39:24 +02:00
authentication backend to be able to log in again. The new name better reflects
what's going on. A similar change
2016-04-13 13:47:11 +02:00
affects environments that opted for not storing preferences, your new backend is `none` .