icingaweb2/packages/rpm/README.md

3.1 KiB

Icinga Web 2 README for RPM Packages

This file will describe how to install Icinga Web 2 from an RPM package (RHEL/CentOS/Fedora, SLES/OpenSUSE).

Requirements

  • EPEL/OBS Repository for Zend Framework
  • Apache 2.2+
  • PHP 5.3+, Zend Framework, PHP PDO MySQL/PostgreSQL, PHP LDAP (optional)
  • MySQL or PostgreSQL for internal DB
  • Icinga 1.x or 2.x providing an IDO database (default: icinga)
  • Icinga 1.x or 2.x providing an external command pipe (default: icinga2.cmd)

SELinux

Disabled SELinux for sending commands via external command pipe provided by Icinga (2) Core.

setenforce 0

Webserver Configuration

Can be generated using the following local icingacli command:

/usr/share/icingaweb2/bin/icingacli setup config webserver apache

Pipe the output into /etc/httpd/conf.d/icingaweb2.conf or similar, if not already existing.

Setup Wizard

Navigate to /icingaweb/setup and follow the on-screen instructions.

Support

Please use one of the listed support channels at https://support.icinga.org

Manual Setup

Internal DB Setup

Decide whether to use MySQL or PostgreSQL.

MySQL

mysql -u root -p
    CREATE USER `icingaweb`@`localhost` IDENTIFIED BY 'icingaweb';
    CREATE DATABASE `icingaweb`;
    GRANT ALL PRIVILEGES ON `icingaweb`.* TO `icingaweb`@`localhost`;
    FLUSH PRIVILEGES;
    quit

mysql -u root -p icingaweb < /usr/share/doc/icingaweb2*/schema/mysql.schema..sql

PostgreSQL

sudo su postgres
psql
postgres=#  CREATE USER icingaweb WITH PASSWORD 'icingaweb';
postgres=#  CREATE DATABASE icingaweb;
postgres=#  \q

Add the cingaweb user for trusted authentication to your pg_hba.conf file in /var/lib/pgsql/data/pg_hba.conf and restart the PostgreSQL server.

local   icingaweb      icingaweb                            trust
host    icingaweb      icingaweb      127.0.0.1/32          trust
host    icingaweb      icingaweb      ::1/128               trust

Now install the icingaweb schema

bash$  psql -U icingaweb -a -f /usr/share/doc/icingaweb2*/schema/pgsql.schema.sql

Configuration

Module Configuration

The monitoring module is enabled by default.

Backend configuration

/etc/icingaweb2/resources.ini contains the database backend information. By default the Icinga 2 DB IDO is used by the monitoring module in /etc/icingaweb2/modules/monitoring/backends.ini

The external command pipe is required for sending commands and configured for Icinga 2 in /etc/icingaweb2/modules/monitoring/instances.ini

Authentication configuration

The /etc/icingaweb2/authentication.ini file uses the internal database as default. This requires the database being installed properly before allowing users to login via web console.

Default User

When not using the default setup wizard, you can generate a secure password hash with openssl and insert that manually like so:

openssl passwd -1 "yoursecurepassword"

mysql -uicingaweb -p icingaweb

mysql> INSERT INTO icingaweb_user (name, active, password_hash) VALUES ('icingaadmin', 1, '$yoursecurepassword_hash');