Project

General

Profile

Install Icinga2 and Icingaweb2 » History » Version 14

Jon Goldberg, 10/04/2017 10:06 PM

1 1 Jon Goldberg
{{last_updated_at}} by {{last_updated_by}}
2
# Install Icinga2 and Icingaweb2
3
4
{{>toc}}
5
6
### Installation (Master Node)
7
8 4 Jon Goldberg
Steps are adapted from [this guide](http://linoxide.com/ubuntu-how-to/install-icinga2-ubuntu-16-04/).
9 1 Jon Goldberg
10 4 Jon Goldberg
#### Install Icinga2
11 11 Jon Goldberg
```bash
12 5 Jon Goldberg
# Install MySQL if you haven't yet
13
14 4 Jon Goldberg
# These lines for Ubuntu 16.04 only:
15
apt install software-properties-common
16
add-apt-repository -y ppa:formorer/icinga
17
apt update
18
apt-get install icinga2
19 5 Jon Goldberg
apt-get install icinga2-ido-mysql
20 4 Jon Goldberg
21
# These 3 lines for Debian 8 only:
22
echo 'deb http://ftp.debian.org/debian jessie-backports main' > /etc/apt/sources.list.d/jessie-backports.list
23
apt-get update
24 1 Jon Goldberg
apt-get -t jessie-backports install icinga2
25 5 Jon Goldberg
apt-get -t jessie-backports install icinga2-ido-mysql
26 4 Jon Goldberg
27
systemctl enable icinga2.service
28 1 Jon Goldberg
systemctl start icinga2.service
29 5 Jon Goldberg
apt install nagios-plugins
30
# nagios-plugins has Samba as a dependency, but you should remove it.
31
apt remove samba-common samba-libs
32
icinga2 feature enable ido-mysql
33
systemctl restart icinga2.service
34
35 4 Jon Goldberg
```
36 1 Jon Goldberg
37
#### Install Icingaweb2
38 11 Jon Goldberg
```bash
39 5 Jon Goldberg
40
# If Ubuntu 16.04, you need to work around this bug: https://bugs.launchpad.net/ubuntu/+source/icingaweb2/+bug/1574250
41 1 Jon Goldberg
# FIRST, uncomment the second line in /etc/php/7.0/mods-available/zend-framework.ini
42
phpenmod zend-framework
43
systemctl restart apache2.service
44 5 Jon Goldberg
# END Ubuntu 16.04 workaround
45
46
apt install icingaweb2
47 4 Jon Goldberg
```
48 6 Jon Goldberg
* Go to http://<your IP>/icingaweb2/setup.
49
* Finish from here: https://linoxide.com/ubuntu-how-to/install-icinga2-ubuntu-16-04, starting with "Configuring Icinga Web2 plugin"
50 1 Jon Goldberg
51
### Configuration
52
53
-   Run `icinga2 node wizard. `Select "N" to create a master node.
54 8 Jon Goldberg
-   Enable the api and command module to allow issuing commands from Icingaweb2 and to allow API:
55
    `icinga2 feature enable api command; service icinga2 restart`
56 1 Jon Goldberg
-   Add an API user for remote checks.  For instance, a user that can
57 9 Jon Goldberg
    receive backupninja checks.  Add this to `/etc/icinga2/conf.d/api-users.conf`:
58 1 Jon Goldberg
59 11 Jon Goldberg
    ```
60 1 Jon Goldberg
    object ApiUser "backupninja" {
61
      password = "<redacted>"
62
      permissions = [
63
        {
64
          permission = "actions/process-check-result"
65
          filter = {{ match("backupninja", service.display_name) }}
66
        }
67 14 Jon Goldberg
       {
68
         permission = "actions/reschedule-check"
69
         filter = {{ match("backupninja", service.display_name) }}
70
       }
71 1 Jon Goldberg
      ]
72
    }
73
    ```
74
75 12 Jon Goldberg
### Open the firewall
76
Open port 5665 on the master node's firewall.  Edit the files in `/etc/iptables` and restart `netfilter-persistent`.
77
78 1 Jon Goldberg
### Install additional checks
79
80
#### Install Plugins
81
82
Place the following two scripts in your plugins directory
83
(`/usr/lib/nagios/plugins`) and ensure they're executable:
84
85 11 Jon Goldberg
-   **check_drupal** - installs with the Drupal "nagios" plugin, also
86 1 Jon Goldberg
    available
87 2 Jon Goldberg
    [here](http://cgit.drupalcode.org/nagios/plain/nagios-plugin/check_drupal?id=7da732e2d4943ec5368243f4cd2e33eb02769f23).
88 11 Jon Goldberg
-   **check_civicrm** - There are two scripts - one for Civi 4.6 and
89 1 Jon Goldberg
    below, another for 4.7 and up.  4.7 version is available
90 10 Jon Goldberg
    [here](https://raw.githubusercontent.com/PalanteJon/check_civicrm/master/check_civicrm.php),
91
    4.6 version is [here](https://raw.githubusercontent.com/aghstrategies/com.aghstrategies.civimonitor/master/check_civicrm.php).
92 11 Jon Goldberg
-   **check_domain** - This does a WHOIS lookup to ensure domain names aren't about to expire.  Install from
93 10 Jon Goldberg
    [here](https://raw.githubusercontent.com/glensc/monitoring-plugin-check_domain/master/check_domain.sh).
94 11 Jon Goldberg
-   **check_rbl** - Check spam blacklists.  File is [here](https://raw.githubusercontent.com/matteocorti/check_rbl/master/check_rbl), also install dependencies:
95 2 Jon Goldberg
    `apt install libreadonly-xs-perl libnagios-plugin-perl libdata-validate-ip-perl libdata-validate-domain-perl libnet-dns-perl`
96 1 Jon Goldberg
97 2 Jon Goldberg
#### Define CheckCommand and Service objects for the new plugins
98 1 Jon Goldberg
99 2 Jon Goldberg
Copy the CheckCommand and Service files from
100 1 Jon Goldberg
`icinga.jmaconsulting.biz:/etc/icinga2/zones.d/global-templates/CheckCommands`
101 2 Jon Goldberg
and `icinga.jmaconsulting.biz:/etc/icinga2/conf.d/services`. See [[Add New Checks to Icinga2]] for details.
102 1 Jon Goldberg
103 13 Jon Goldberg
### Harden the TLS connection
104
Add this line to the bottom of the "api" object in `/etc/icinga2/features-available/api.conf`:
105
```
106
tls_protocolmin = "TLSv1.2"
107
```
108 1 Jon Goldberg
109 2 Jon Goldberg
### Set up vim syntax highlighting on the Icinga2 server
110 11 Jon Goldberg
```bash
111 2 Jon Goldberg
mkdir -p ~/.vim/{syntax,ftdetect}
112
cd ~/.vim/syntax
113
wget https://raw.githubusercontent.com/Icinga/icinga2/master/tools/syntax/vim/syntax/icinga2.vim
114
cd ~/.vim/ftdetect
115
wget https://raw.githubusercontent.com/Icinga/icinga2/master/tools/syntax/vim/ftdetect/icinga2.vim
116
```