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 | ``` |