]> granicus.if.org Git - icinga2/blob - doc/14-addons-plugins.md
f921c5091fa33bf9a94af3dd8bfc7e19d27b319c
[icinga2] / doc / 14-addons-plugins.md
1 # <a id="addons-plugins"></a> Icinga 2 Addons and Plugins
2
3 ## <a id="addons-graphing"></a> Graphing
4
5 ### <a id="addons-graphing-pnp"></a> PNP
6
7 [PNP](http://www.pnp4nagios.org) is a graphing addon.
8
9 [PNP](http://www.pnp4nagios.org) is an addon which adds a graphical representation of the performance data collected
10 by the monitoring plugins. The data is stored as rrd (round robin database) files.
11
12 Use your distribution's package manager to install the `pnp4nagios` package.
13
14 If you're planning to use it, configure it to use the
15 [bulk mode with npcd and npcdmod](http://docs.pnp4nagios.org/pnp-0.6/modes#bulk_mode_with_npcd_and_npcdmod)
16 in combination with Icinga 2's [PerfdataWriter](15-features.md#performance-data). NPCD collects the performance
17 data files which Icinga 2 generates.
18
19 Enable performance data writer in icinga 2
20
21     # icinga2 feature enable perfdata
22
23 Configure npcd to use the performance data created by Icinga 2:
24
25     vim /etc/pnp4nagios/npcd.cfg
26
27 Set `perfdata_spool_dir = /var/spool/icinga2/perfdata` and restart the `npcd` daemon.
28
29 There's also an Icinga Web 2 module for direct PNP graph integration
30 available at [Icinga Exchange](https://exchange.icinga.org/icinga/PNP).
31
32 More information on [action_url as attribute](14-addons-plugins.md#addons-graphing-pnp-action-url)
33 and [graph template names](14-addons-plugins.md#addons-graphing-pnp-custom-templates).
34
35
36 ### <a id="addons-graphing-graphite"></a> Graphite
37
38 [Graphite](http://graphite.readthedocs.org/en/latest/) is a time-series database
39 storing collected metrics and making them available through restful apis
40 and web interfaces.
41
42 Graphite consists of 3 software components:
43
44 * carbon -- a Twisted daemon that listens for time-series data
45 * whisper -- a simple database library for storing time-series data (similar in design to RRD)
46 * graphite webapp -- a Django webapp that renders graphs on-demand using Cairo
47
48 Use the [GraphiteWriter](15-features.md#graphite-carbon-cache-writer) feature
49 for sending real-time metrics from Icinga 2 to Graphite.
50
51     # icinga2 feature enable graphite
52
53 There are Graphite addons available for collecting the performance data files too (e.g. `Graphios`).
54
55 A popular alternative frontend for Graphite is for example [Grafana](http://grafana.org).
56
57 ### <a id="addons-graphing-influxdb"></a> InfluxDB
58
59 [InfluxDB](https://influxdb.com) is a time series, metrics, and analytics database.
60 It’s written in Go and has no external dependencies.
61
62 Use the [InfluxdbWriter](15-features.md#influxdb-writer) feature
63 for sending real-time metrics from Icinga 2 to InfluxDB.
64
65     # icinga2 feature enable influxdb
66
67 A popular frontend for InfluxDB is for example [Grafana](http://grafana.org).
68
69 ## <a id="addons-visualization"></a> Visualization
70
71 ### <a id="addons-visualization-reporting"></a> Icinga Reporting
72
73 By enabling the [DB IDO](15-features.md#db-ido) feature you can use the
74 [Icinga Reporting package](https://wiki.icinga.org/display/howtos/Setting+up+Icinga+with+Reporting).
75
76 ### <a id="addons-visualization-nagvis"></a> NagVis
77
78 By using either [Livestatus](15-features.md#setting-up-livestatus) or
79 [DB IDO](15-features.md#db-ido) as a backend you can create your own network maps
80 based on your monitoring configuration and status data using [NagVis](http://www.nagvis.org).
81
82 The configuration in nagvis.ini.php should look like this for Livestatus for example:
83
84     [backend_live_1]
85     backendtype="mklivestatus"
86     socket="unix:/var/run/icinga2/cmd/livestatus"
87
88 If you are planning an integration into Icinga Web 2, look at [this module](https://github.com/Icinga/icingaweb2-module-nagvis).
89
90 ### <a id="addons-visualization-thruk"></a> Thruk
91
92 [Thruk](http://www.thruk.org) is an alternative web interface which can be used with Icinga 2
93 and the [Livestatus](15-features.md#setting-up-livestatus) feature.
94
95 ## <a id="log-monitoring"></a> Log Monitoring
96
97 Using [Logstash](https://www.elastic.co/guide/en/logstash/current/introduction.html) or
98 [Graylog](https://www.graylog.org) in your infrastructure and correlate events with your monitoring
99 is even simpler these days.
100
101 * Use the `GelfWriter` feature to write Icinga 2's check and notification events to Graylog or Logstash.
102 * Configure the logstash `nagios` output to send passive traps to Icinga 2 using the external command pipe.
103 * Execute a plugin to check Graylog alert streams.
104
105 More details can be found in [this blog post](https://www.icinga.org/2014/12/02/team-icinga-at-osmc-2014/).
106
107 ## <a id="notification-scripts-interfaces"></a> Notification Scripts and Interfaces
108
109 There's a variety of resources available, for example different notification scripts such as:
110
111 * E-Mail ([examples](3-monitoring-basics.md#notifications) provided)
112 * SMS
113 * Pager (XMPP, etc.)
114 * Twitter
115 * IRC
116 * Ticket systems
117 * etc.
118
119 Additionally external services can be [integrated with Icinga 2](https://www.icinga.org/icinga/integration/):
120
121 * [Pagerduty](https://www.icinga.org/partners/pagerduty/)
122 * [VictorOps](https://www.icinga.org/partners/victorops/)
123 * [StackStorm](https://www.icinga.org/partners/stackstorm/)
124
125 More information can be found on the [Icinga Website](https://www.icinga.org/)
126 and the [Icinga Wiki](https://wiki.icinga.org/display/howtos/Home).
127
128 ## <a id="configuration-tools"></a> Configuration Management Tools
129
130 If you require your favourite configuration tool to export the Icinga 2 configuration, please get in
131 touch with their developers. The Icinga project does not provide a configuration web interface
132 yet. Follow the [Icinga Blog](https://www.icinga.org/blog/) for updates on this topic.
133
134 If you're looking for puppet manifests, chef cookbooks, ansible recipes, etc. -- we're happy
135 to integrate them upstream, so please get in touch with the [Icinga team](https://www.icinga.org/community/get-involved/).
136
137 These tools are currently in development and require feedback and tests:
138
139 * [Ansible Roles](https://github.com/Icinga/icinga2-ansible)
140 * [Puppet Module](https://github.com/Icinga/puppet-icinga2)
141 * [Chef Cookbook](https://github.com/Icinga/chef-icinga2)
142
143 ## <a id="plugins"></a> Plugins
144
145 For some services you may need additional 'check plugins' which are not provided
146 by the official Monitoring Plugins project.
147
148 All existing Nagios or Icinga 1.x plugins work with Icinga 2. Here's a
149 list of popular community sites which host check plugins:
150
151 * [Icinga Exchange](https://exchange.icinga.org)
152 * [Icinga Wiki](https://wiki.icinga.org)
153
154 The recommended way of setting up these plugins is to copy them to a common directory
155 and create a new global constant, e.g. `CustomPluginDir` in your [constants.conf](4-configuring-icinga-2.md#constants-conf)
156 configuration file:
157
158     # cp check_snmp_int.pl /opt/monitoring/plugins
159     # chmod +x /opt/plugins/check_snmp_int.pl
160
161     # cat /etc/icinga2/constants.conf
162     /**
163      * This file defines global constants which can be used in
164      * the other configuration files. At a minimum the
165      * PluginDir constant should be defined.
166      */
167
168     const PluginDir = "/usr/lib/nagios/plugins"
169     const CustomPluginDir = "/opt/monitoring/plugins"
170
171 Prior to using the check plugin with Icinga 2 you should ensure that it is working properly
172 by trying to run it on the console using whichever user Icinga 2 is running as:
173
174     # su - icinga -s /bin/bash
175     $ /opt/monitoring/plugins/check_snmp_int.pl --help
176
177 Additional libraries may be required for some plugins. Please consult the plugin
178 documentation and/or plugin provided README for installation instructions.
179 Sometimes plugins contain hard-coded paths to other components. Instead of changing
180 the plugin it might be easier to create logical links which is (more) update-safe.
181
182 Each plugin requires a [CheckCommand](6-object-types.md#objecttype-checkcommand) object in your
183 configuration which can be used in the [Service](6-object-types.md#objecttype-service) or
184 [Host](6-object-types.md#objecttype-host) object definition.
185
186 There are the following conventions to follow when adding a new command object definition:
187
188 * Always import the `plugin-check-command` template
189 * Use [command-arguments](#) whenever possible. The `command` attribute must be an array
190 in `[ ... ]` then for shell escaping.
191 * Define a unique `prefix` for the command's specific command arguments. That way you can safely
192 set them on host/service level and you'll always know which command they control.
193 * Use command argument default values, e.g. for thresholds
194 * Use [advanced conditions](6-object-types.md#objecttype-checkcommand) like `set_if` definitions.
195
196 Example for a custom `my-snmp-int` check command:
197
198     object CheckCommand "my-snmp-int" {
199       import "plugin-check-command"
200
201       command = [ CustomPluginDir + "/check_snmp_int.pl" ]
202
203       arguments = {
204         "-H" = "$snmp_address$"
205         "-C" = "$snmp_community$"
206         "-p" = "$snmp_port$"
207         "-2" = {
208           set_if = "$snmp_v2$"
209         }
210         "-n" = "$snmp_interface$"
211         "-f" = {
212           set_if = "$snmp_perf$"
213         }
214         "-w" = "$snmp_warn$"
215         "-c" = "$snmp_crit$"
216       }
217
218       vars.snmp_v2 = true
219       vars.snmp_perf = true
220       vars.snmp_warn = "300,400"
221       vars.snmp_crit = "0,600"
222     }
223
224 Icinga 2 has built-in check command definitions for the [Manubulon Plugin Checks](7-icinga-template-library.md#snmp-manubulon-plugin-check-commands).
225
226 For further information on your monitoring configuration read the
227 [Monitoring Basics](3-monitoring-basics.md#monitoring-basics) chapter.
228
229 You can find additional plugins at the [Icinga Exchange](https://exchange.icinga.org)
230
231 More details on the plugins can also be found on the Icinga Wiki at https://wiki.icinga.org
232
233 > **Tip**
234 >
235 > Create the best `CheckCommand` definition there is and send it upstream. More
236 > information can be found in [Contribute Icinga 2 ITL Plugin Check Command Definitions](https://wiki.icinga.org/display/community/Contribute+Icinga+2+ITL+Plugin+Check+Command+Definitions)
237 > on the Icinga Wiki. Thank you in advance!
238
239 ## <a id="plugin-api"></a> Plugin API
240
241 Currently Icinga 2 supports the native plugin API specification from the `Monitoring Plugins`
242 project.
243
244 The `Monitoring Plugin API` is defined in the [Monitoring Plugins Development Guidelines](https://www.monitoring-plugins.org/doc/guidelines.html).
245
246 There are no output length restrictions using Icinga 2. This is different to the
247 [Icinga 1.x plugin api definition](http://docs.icinga.org/latest/en/pluginapi.html#outputlengthrestrictions).
248
249
250 ## <a id="addon-integration-hints"></a> More Addon Integration Hints
251
252 ### <a id="addons-graphing-pnp-action-url"></a> PNP Action Url
253
254 They work in a similar fashion for Icinga 2 and are used for 1.x web interfaces (Icinga Web 2 doesn't require
255 the action url attribute in its own module).
256
257     template Service "pnp-hst" {
258       action_url = "/pnp4nagios/graph?host=$HOSTNAME$"
259     }
260
261     template Service "pnp-svc" {
262       action_url = "/pnp4nagios/graph?host=$HOSTNAME$&srv=$SERVICEDESC$"
263     }
264
265 ### <a id="addons-graphing-pnp-custom-templates"></a> PNP Custom Templates with Icinga 2
266
267 PNP automatically determines the graph template from the check command name (or the argument's name).
268 This behavior changed in Icinga 2 compared to Icinga 1.x. Though there are certain possibilities to
269 fix this:
270
271 * Create a symlink for example from the `templates.dist/check_ping.php` template to the actual check name in Icinga 2 (`templates/ping4.php`)
272 * Pass the check command name inside the [format template configuration](15-features.md#writing-performance-data-files)
273
274 The latter becomes difficult with agent based checks like NRPE or SSH where the first command argument acts as
275 graph template identifier. There is the possibility to define the pnp template name as custom attribute
276 and use that inside the formatting templates as `SERVICECHECKCOMMAND` for instance.
277
278 Example for services:
279
280     # vim /etc/icinga2/features-enabled/perfdata.conf
281
282     service_format_template = "DATATYPE::SERVICEPERFDATA\tTIMET::$icinga.timet$\tHOSTNAME::$host.name$\tSERVICEDESC::$service.name$\tSERVICEPERFDATA::$service.perfdata$\tSERVICECHECKCOMMAND::$service.check_command$$pnp_check_arg1$\tHOSTSTATE::$host.state$\tHOSTSTATETYPE::$host.state_type$\tSERVICESTATE::$service.state$\tSERVICESTATETYPE::$service.state_type$"
283
284     # vim /etc/icinga2/conf.d/services.conf
285
286     template Service "pnp-svc" {
287       action_url = "/pnp4nagios/graph?host=$HOSTNAME$&srv=$SERVICEDESC$"
288       vars.pnp_check_arg1 = ""
289     }
290
291     apply Service "nrpe-check" {
292       import "pnp-svc"
293       check_command = nrpe
294       vars.nrpe_command = "check_disk"
295
296       vars.pnp_check_arg1 = "!$nrpe_command$"
297     }
298
299 If there are warnings about unresolved macros, make sure to specify a default value for `vars.pnp_check_arg1` inside the
300
301 In PNP, the custom template for nrpe is then defined in `/etc/pnp4nagios/custom/nrpe.cfg`
302 and the additional command arg string will be seen in the xml too for other templates.