2016-08-24 08:12:20 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								source: Extensions/Services.md
							 
						 
					
						
							
								
									
										
										
										
											2015-06-27 21:22:59 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								# Setting up Services
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Services within LibreNMS provides the ability to use Nagios plugins to perform additional monitoring outside of SNMP.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2016-01-30 21:06:58 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								These services are tied into an existing device so you need at least one device that supports SNMP to be able to add it
							 
						 
					
						
							
								
									
										
										
										
											2015-11-04 20:18:36 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								to LibreNMS - localhost is a good one.
							 
						 
					
						
							
								
									
										
										
										
											2015-06-27 21:22:59 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								## Setup
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Firstly, install Nagios plugins however you would like, this could be via yum, apt-get or direct from source.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Next, you need to enable the services within config.php with the following:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```php
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								$config['show_services']           = 1;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								This will enable a new service menu within your navbar.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```php
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								$config['nagios_plugins']   = "/usr/lib/nagios/plugins";
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								This will point LibreNMS at the location of the nagios plugins - please ensure that any plugins you use are set to executable.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2016-03-29 17:11:21 +10:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Finally, you now need to add check-services.php to the current cron file (/etc/cron.d/librenms typically) like:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```bash
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								*/5 *   *  *   *  librenms /opt/librenms/check-services.php >> /dev/null 2>&1
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2016-03-15 22:16:08 +10:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Now you can add services via the main Services link in the navbar, or via the 'Add Service' link within the device, services page.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								## Performance data
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2016-03-29 17:11:21 +10:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								By default, the check-services script will collect all performance data that the Nagios script returns and display each datasource on a separate graph.
							 
						 
					
						
							
								
									
										
										
										
											2016-03-15 22:16:08 +10:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								However for some modules it would be better if some of this information was consolidated on a single graph.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								An example is the ICMP check. This check returns: Round Trip Average (rta), Round Trip Min (rtmin) and Round Trip Max (rtmax).
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								These have been combined onto a single graph.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2016-03-29 17:11:21 +10:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								If you find a check script that would benefit from having some datasources graphed together, please log an issue on GitHub with the debug information from the script, and let us know which DS's should go together. Example below:
							 
						 
					
						
							
								
									
										
										
										
											2016-03-15 22:16:08 +10:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2016-03-29 17:11:21 +10:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    ./check-services.php -d
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    -- snip --
							 
						 
					
						
							
								
									
										
										
										
											2016-03-15 22:16:08 +10:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    Nagios Service - 26
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    Request:  /usr/lib/nagios/plugins/check_icmp localhost
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    Perf Data - DS: rta, Value: 0.016, UOM: ms
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    Perf Data - DS: pl, Value: 0, UOM: %
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    Perf Data - DS: rtmax, Value: 0.044, UOM: ms
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    Perf Data - DS: rtmin, Value: 0.009, UOM: ms
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    Response: OK - localhost: rta 0.016ms, lost 0%
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    Service DS: {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        "rta": "ms",
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        "pl": "%",
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        "rtmax": "ms",
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        "rtmin": "ms"
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    }
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    OK u:0.00 s:0.00 r:40.67
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    RRD[update /opt/librenms/rrd/localhost/services-26.rrd N:0.016:0:0.044:0.009]
							 
						 
					
						
							
								
									
										
										
										
											2016-03-29 17:11:21 +10:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    -- snip --
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								## Alerting
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Services uses the Nagios Alerting scheme where:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									0 = Ok,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									1 = Warning,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									2 = Critical,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								To create an alerting rule to alert on service=critical, your alerting rule would look like:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    %services.service_status = "2"