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
|
|
|
|
|
2014-11-18 16:56:39 +01:00
|
|
|
|
## <a id="installation-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-01-14 14:14:44 +01:00
|
|
|
|
* PHP >= 5.3.0 w/ gettext and OpenSSL support
|
2014-11-18 16:56:39 +01:00
|
|
|
|
* MySQL or PostgreSQL PHP libraries when using a database for authentication or storing user preferences into a database
|
|
|
|
|
* LDAP PHP library when using Active Directory or LDAP for authentication
|
|
|
|
|
* Icinga 1.x w/ Livestatus or IDO, Icinga 2 w/ Livestatus or IDO feature enabled
|
2013-10-20 14:51:03 +02:00
|
|
|
|
|
2014-11-18 16:56:39 +01:00
|
|
|
|
## <a id="installation-from-package"></a> Installing Icinga Web 2 from Package
|
2013-10-20 14:51:03 +02:00
|
|
|
|
|
2014-11-18 16:56:39 +01:00
|
|
|
|
A guide on how to install Icinga Web 2 from package will follow shortly.
|
2013-07-03 14:00:55 +02:00
|
|
|
|
|
2014-11-18 16:56:39 +01:00
|
|
|
|
## <a id="installation-from-source"></a> Installing Icinga Web 2 from Source
|
2013-07-03 14:00:55 +02:00
|
|
|
|
|
2014-11-18 16:56:39 +01:00
|
|
|
|
**Step 1: 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
|
|
|
|
|
2014-11-18 16:56:39 +01:00
|
|
|
|
````
|
|
|
|
|
git clone git://git.icinga.org/icingaweb2.git
|
|
|
|
|
````
|
2013-08-29 10:55:12 +02:00
|
|
|
|
|
2014-11-18 16:56:39 +01:00
|
|
|
|
**Step 2: Install the Source**
|
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
|
|
|
|
|
2014-11-18 16:56:39 +01:00
|
|
|
|
````
|
2015-01-13 13:08:09 +01:00
|
|
|
|
mv icingaweb2 /usr/share/icingaweb2
|
2014-11-18 16:56:39 +01:00
|
|
|
|
````
|
2013-07-03 14:00:55 +02:00
|
|
|
|
|
2014-11-18 16:56:39 +01:00
|
|
|
|
**Step 3: 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-01-14 13:24:04 +01:00
|
|
|
|
Apache:
|
2014-11-18 16:56:39 +01:00
|
|
|
|
````
|
2015-01-13 13:08:09 +01:00
|
|
|
|
./bin/icingacli setup config webserver apache --document-root /usr/share/icingaweb2/public
|
2014-11-18 16:56:39 +01:00
|
|
|
|
````
|
2013-07-26 12:58:21 +02:00
|
|
|
|
|
2015-01-14 13:24:04 +01:00
|
|
|
|
nginx:
|
2014-11-18 16:56:39 +01:00
|
|
|
|
````
|
2015-01-13 13:08:09 +01:00
|
|
|
|
./bin/icingacli setup config webserver nginx --document-root /usr/share/icingaweb2/public
|
2014-11-18 16:56:39 +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.
|
|
|
|
|
|
|
|
|
|
Example for Apache on RHEL/CentOS:
|
|
|
|
|
````
|
|
|
|
|
./bin/icingacli setup config webserver apache --document-root /usr/share/icingaweb2/public > /etc/httpd/conf.d/icingaweb2.conf
|
|
|
|
|
````
|
|
|
|
|
|
|
|
|
|
|
2015-01-14 13:24:04 +01:00
|
|
|
|
**Step 4: Preparing Web Setup**
|
|
|
|
|
|
|
|
|
|
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.
|
|
|
|
|
|
|
|
|
|
Fedora, RHEL, CentOS, SLES and OpenSUSE:
|
|
|
|
|
````
|
|
|
|
|
groupadd -r icingaweb2
|
|
|
|
|
````
|
|
|
|
|
|
|
|
|
|
Debian and Ubuntu:
|
|
|
|
|
````
|
|
|
|
|
addgroup --system icingaweb2
|
|
|
|
|
````
|
|
|
|
|
|
|
|
|
|
Add your web server's user to the system group `icingaweb2`:
|
|
|
|
|
|
|
|
|
|
Fedora, RHEL and CentOS:
|
|
|
|
|
````
|
|
|
|
|
usermod -a -G icingaweb2 apache
|
|
|
|
|
````
|
|
|
|
|
|
|
|
|
|
SLES and OpenSUSE:
|
|
|
|
|
````
|
2015-02-04 17:23:07 +01:00
|
|
|
|
usermod -A icingaweb2 wwwrun
|
2015-01-14 13:24:04 +01:00
|
|
|
|
````
|
|
|
|
|
|
|
|
|
|
Debian and Ubuntu:
|
|
|
|
|
````
|
2015-02-04 23:50:58 +01:00
|
|
|
|
usermod -a -G icingaweb2 www-data
|
2015-01-14 13:24:04 +01:00
|
|
|
|
````
|
|
|
|
|
|
|
|
|
|
Use `icingacli` to create the configuration directory which defaults to **/etc/icingaweb2**:
|
|
|
|
|
````
|
|
|
|
|
./bin/icingacli setup config directory
|
|
|
|
|
````
|
|
|
|
|
|
|
|
|
|
When using the web setup you are required to authenticate using a token. In order to generate a token use the
|
|
|
|
|
`icingacli`:
|
|
|
|
|
````
|
|
|
|
|
./bin/icingacli setup token create
|
|
|
|
|
````
|
|
|
|
|
|
|
|
|
|
In case you do not remember the token you can show it using the `icingacli`:
|
|
|
|
|
````
|
|
|
|
|
./bin/icingacli setup token show
|
|
|
|
|
````
|
|
|
|
|
|
|
|
|
|
**Step 5: Web Setup**
|
2013-07-26 12:58:21 +02:00
|
|
|
|
|
2015-01-28 17:59:43 +01:00
|
|
|
|
Visit Icinga Web 2 in your browser and complete installation using the web setup: /icingaweb2/setup
|
2015-02-03 16:52:36 +01:00
|
|
|
|
|
|
|
|
|
## Upgrading to Icinga Web 2 Beta 2
|
|
|
|
|
|
|
|
|
|
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.
|
2015-02-04 09:22:27 +01:00
|
|
|
|
|
|
|
|
|
If you delegated authentication to your web server using the `autologin` backend, you have to switch to the `external`
|
|
|
|
|
authentication backend to be able to log in again. The new name better reflects what’s going on. A similar change
|
|
|
|
|
affects environments that opted for not storing preferences, your new backend is `none`.
|