| 
									
										
										
										
											2010-09-03 18:26:59 +00:00
										 |  |  | #!/usr/bin/env php
 | 
					
						
							| 
									
										
										
										
											2009-10-28 13:49:37 +00:00
										 |  |  | <?php | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-03-15 15:12:16 +00:00
										 |  |  | /* Observium Network Management and Monitoring System | 
					
						
							|  |  |  |  * Copyright (C) 2006-2011, Observium Developers - http://www.observium.org | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * This program is free software: you can redistribute it and/or modify | 
					
						
							|  |  |  |  * it under the terms of the GNU General Public License as published by | 
					
						
							|  |  |  |  * the Free Software Foundation, either version 3 of the License, or | 
					
						
							|  |  |  |  * (at your option) any later version. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * See COPYING for more details. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-04-08 10:39:10 +00:00
										 |  |  | chdir(dirname($argv[0])); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-02-27 14:44:38 +00:00
										 |  |  | include("includes/defaults.inc.php"); | 
					
						
							| 
									
										
										
										
											2009-10-28 13:49:37 +00:00
										 |  |  | include("config.php"); | 
					
						
							|  |  |  | include("includes/functions.php"); | 
					
						
							| 
									
										
										
										
											2011-04-13 14:00:12 +00:00
										 |  |  | include("includes/polling/functions.inc.php"); | 
					
						
							| 
									
										
										
										
											2009-10-28 13:49:37 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | $poller_start = utime(); | 
					
						
							| 
									
										
										
										
											2010-07-17 12:58:09 +00:00
										 |  |  | echo("Observium Poller v".$config['version']."\n\n"); | 
					
						
							| 
									
										
										
										
											2009-10-28 13:49:37 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-03 10:45:36 +00:00
										 |  |  | $options = getopt("h:m:i:n:d:r::a::"); | 
					
						
							| 
									
										
										
										
											2009-10-28 13:49:37 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-07-19 18:21:48 +00:00
										 |  |  | if ($options['h'] == "odd")      { $options['n'] = "1"; $options['i'] = "2"; } | 
					
						
							|  |  |  | elseif ($options['h'] == "even") { $options['n'] = "0"; $options['i'] = "2"; } | 
					
						
							|  |  |  | elseif ($options['h'] == "all")  { $where = " "; $doing = "all"; } | 
					
						
							| 
									
										
										
										
											2011-03-15 15:12:16 +00:00
										 |  |  | elseif ($options['h']) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2010-06-23 19:17:06 +00:00
										 |  |  |   if (is_numeric($options['h'])) | 
					
						
							|  |  |  |   { | 
					
						
							| 
									
										
										
										
											2011-03-08 17:12:43 +00:00
										 |  |  |     $where = "AND `device_id` = '".$options['h']."'"; | 
					
						
							| 
									
										
										
										
											2010-07-19 18:21:48 +00:00
										 |  |  |     $doing = $options['h']; | 
					
						
							| 
									
										
										
										
											2010-06-23 19:17:06 +00:00
										 |  |  |   } | 
					
						
							|  |  |  |   else | 
					
						
							|  |  |  |   { | 
					
						
							| 
									
										
										
										
											2011-03-08 17:12:43 +00:00
										 |  |  |     $where = "AND `hostname` LIKE '".str_replace('*','%',mres($options['h']))."'"; | 
					
						
							| 
									
										
										
										
											2010-07-19 18:21:48 +00:00
										 |  |  |     $doing = $options['h']; | 
					
						
							| 
									
										
										
										
											2010-06-23 19:17:06 +00:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2010-07-19 18:21:48 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-03-15 15:12:16 +00:00
										 |  |  | if (isset($options['i']) && $options['i'] && isset($options['n'])) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2011-05-03 11:24:50 +00:00
										 |  |  |   $where = true; // FIXME
 | 
					
						
							|  |  |  |   $query = 'SELECT `device_id` FROM (SELECT @rownum :=0) r, | 
					
						
							|  |  |  |               ( | 
					
						
							|  |  |  |                 SELECT @rownum := @rownum +1 AS rownum, `device_id` | 
					
						
							|  |  |  |                 FROM `devices` | 
					
						
							| 
									
										
										
										
											2011-09-20 09:55:11 +00:00
										 |  |  |                 WHERE `disabled` = 0 | 
					
						
							| 
									
										
										
										
											2011-05-03 11:24:50 +00:00
										 |  |  |                 ORDER BY `device_id` ASC | 
					
						
							|  |  |  |               ) temp | 
					
						
							| 
									
										
										
										
											2011-05-12 17:59:00 +00:00
										 |  |  |             WHERE MOD(temp.rownum, '.mres($options['i']).') = '.mres($options['n']).';'; | 
					
						
							| 
									
										
										
										
											2010-07-19 18:21:48 +00:00
										 |  |  |   $doing = $options['n'] ."/".$options['i']; | 
					
						
							| 
									
										
										
										
											2009-10-28 13:49:37 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-03-15 15:12:16 +00:00
										 |  |  | if (!$where) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2011-03-27 10:21:19 +00:00
										 |  |  |   echo("-h <device id> | <device hostname wildcard>  Poll single device\n"); | 
					
						
							|  |  |  |   echo("-h odd                                       Poll odd numbered devices  (same as -i 2 -n 0)\n"); | 
					
						
							|  |  |  |   echo("-h even                                      Poll even numbered devices (same as -i 2 -n 1)\n"); | 
					
						
							|  |  |  |   echo("-h all                                       Poll all devices\n\n"); | 
					
						
							|  |  |  |   echo("-i <instances> -n <number>                   Poll as instance <number> of <instances>\n"); | 
					
						
							|  |  |  |   echo("                                             Instances start at 0. 0-3 for -n 4\n\n"); | 
					
						
							| 
									
										
										
										
											2011-04-13 09:29:44 +00:00
										 |  |  |   echo("Debugging and testing options:\n"); | 
					
						
							| 
									
										
										
										
											2012-05-03 10:45:36 +00:00
										 |  |  |   echo("-r                                           Do not create or update RRDs\n"); | 
					
						
							| 
									
										
										
										
											2011-04-13 09:29:44 +00:00
										 |  |  |   echo("-d                                           Enable debugging output\n"); | 
					
						
							| 
									
										
										
										
											2012-04-27 17:18:26 +00:00
										 |  |  |   echo("-m                                           Specify module(s) to be run\n"); | 
					
						
							| 
									
										
										
										
											2009-10-28 13:49:37 +00:00
										 |  |  |   echo("\n"); | 
					
						
							|  |  |  |   echo("No polling type specified!\n"); | 
					
						
							|  |  |  |   exit; | 
					
						
							| 
									
										
										
										
											2011-03-27 10:21:19 +00:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2009-10-28 13:49:37 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-03-15 15:12:16 +00:00
										 |  |  | if (isset($options['d'])) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2010-08-21 12:54:42 +00:00
										 |  |  |   echo("DEBUG!\n"); | 
					
						
							|  |  |  |   $debug = TRUE; | 
					
						
							|  |  |  |   ini_set('display_errors', 1); | 
					
						
							|  |  |  |   ini_set('display_startup_errors', 1); | 
					
						
							|  |  |  |   ini_set('log_errors', 1); | 
					
						
							|  |  |  |   ini_set('error_reporting', 1); | 
					
						
							|  |  |  | } else { | 
					
						
							|  |  |  |   $debug = FALSE; | 
					
						
							| 
									
										
										
										
											2010-12-15 17:54:42 +00:00
										 |  |  | #  ini_set('display_errors', 0);
 | 
					
						
							| 
									
										
										
										
											2010-08-21 12:54:42 +00:00
										 |  |  |   ini_set('display_startup_errors', 0); | 
					
						
							|  |  |  |   ini_set('log_errors', 0); | 
					
						
							| 
									
										
										
										
											2010-12-15 17:54:42 +00:00
										 |  |  | #  ini_set('error_reporting', 0);
 | 
					
						
							| 
									
										
										
										
											2010-08-21 12:54:42 +00:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2010-06-23 19:17:06 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-03 10:45:36 +00:00
										 |  |  | if (isset($options['r'])) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   $config['norrd'] = TRUE; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-10-01 14:54:06 +00:00
										 |  |  | rrdtool_pipe_open($rrd_process, $rrd_pipes); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-06-23 19:17:06 +00:00
										 |  |  | echo("Starting polling run:\n\n"); | 
					
						
							|  |  |  | $polled_devices = 0; | 
					
						
							| 
									
										
										
										
											2011-09-20 14:29:04 +00:00
										 |  |  | if (!isset($query)) | 
					
						
							| 
									
										
										
										
											2011-05-03 12:22:04 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2011-05-12 17:59:00 +00:00
										 |  |  |   $query = "SELECT `device_id` FROM `devices` WHERE `disabled` = 0 $where ORDER BY `device_id` ASC"; | 
					
						
							| 
									
										
										
										
											2011-05-03 12:22:04 +00:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2011-03-08 17:14:32 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-05-12 17:59:00 +00:00
										 |  |  | foreach (dbFetch($query) as $device) | 
					
						
							| 
									
										
										
										
											2010-07-18 18:28:32 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2011-05-12 17:59:00 +00:00
										 |  |  |   $device = dbFetchRow("SELECT * FROM `devices` WHERE `device_id` = '".$device['device_id']."'"); | 
					
						
							| 
									
										
										
										
											2011-05-03 21:17:04 +00:00
										 |  |  |   poll_device($device, $options); | 
					
						
							| 
									
										
										
										
											2012-01-25 05:50:21 +00:00
										 |  |  |   $polled_devices++; | 
					
						
							| 
									
										
										
										
											2011-05-03 21:17:04 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-09-20 14:29:04 +00:00
										 |  |  | $poller_end = utime(); $poller_run = $poller_end - $poller_start; $poller_time = substr($poller_run, 0, 5); | 
					
						
							| 
									
										
										
										
											2011-05-03 21:17:04 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-09-20 14:29:04 +00:00
										 |  |  | if ($polled_devices) | 
					
						
							| 
									
										
										
										
											2011-05-08 00:13:58 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2011-09-20 14:29:04 +00:00
										 |  |  |   dbInsert(array('type' => 'poll', 'doing' => $doing, 'start' => $poller_start, 'duration' => $poller_time, 'devices' => $polled_devices ), 'perf_times'); | 
					
						
							| 
									
										
										
										
											2011-05-08 00:13:58 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-09-20 14:29:04 +00:00
										 |  |  | $string = $argv[0] . " $doing " .  date("F j, Y, G:i") . " - $polled_devices devices polled in $poller_time secs"; | 
					
						
							|  |  |  | if ($debug) { echo("$string\n"); } | 
					
						
							| 
									
										
										
										
											2011-05-13 11:42:26 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-09-20 14:29:04 +00:00
										 |  |  | echo('MySQL: Cell['.($db_stats['fetchcell']+0).'/'.round($db_stats['fetchcell_sec']+0,2).'s]'. | 
					
						
							|  |  |  |             ' Row['   .($db_stats['fetchrow']+0). '/'.round($db_stats['fetchrow_sec']+0,2).'s]'. | 
					
						
							|  |  |  |            ' Rows['   .($db_stats['fetchrows']+0).'/'.round($db_stats['fetchrows_sec']+0,2).'s]'. | 
					
						
							|  |  |  |          ' Column['.($db_stats['fetchcol']+0). '/'.round($db_stats['fetchcol_sec']+0,2).'s]'. | 
					
						
							|  |  |  |          ' Update['   .($db_stats['update']+0).'/'.round($db_stats['update_sec']+0,2).'s]'. | 
					
						
							|  |  |  |          ' Insert['.($db_stats['insert']+0). '/'.round($db_stats['insert_sec']+0,2).'s]'. | 
					
						
							|  |  |  |          ' Delete['.($db_stats['delete']+0). '/'.round($db_stats['delete_sec']+0,2).'s]'); | 
					
						
							| 
									
										
										
										
											2011-05-20 14:27:53 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-09-20 14:29:04 +00:00
										 |  |  | echo("\n"); | 
					
						
							| 
									
										
										
										
											2010-11-24 11:32:53 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-09-20 14:29:04 +00:00
										 |  |  | logfile($string); | 
					
						
							| 
									
										
										
										
											2011-10-01 14:54:06 +00:00
										 |  |  | rrdtool_pipe_close($rrd_process, $rrd_pipes); | 
					
						
							| 
									
										
										
										
											2011-09-20 14:29:04 +00:00
										 |  |  | unset($config); ### Remove this for testing
 | 
					
						
							| 
									
										
										
										
											2010-07-23 13:42:28 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-09-20 14:29:04 +00:00
										 |  |  | #print_r(get_defined_vars());
 | 
					
						
							| 
									
										
										
										
											2010-07-23 13:42:28 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-04-06 18:26:16 +00:00
										 |  |  | ?>
 |