mirror of
				https://github.com/librenms/librenms.git
				synced 2024-10-07 16:52:45 +00:00 
			
		
		
		
	git-svn-id: http://www.observium.org/svn/observer/trunk@2814 61d68cd4-352d-0410-923a-c4978735b2b8
		
			
				
	
	
		
			69 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			69 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
<?php
 | 
						|
 | 
						|
$rserver_array = snmpwalk_cache_oid($device, "cesServerFarmRserverTable", array(), "CISCO-ENHANCED-SLB-MIB");
 | 
						|
$rserver_db = dbFetchRows("SELECT * FROM `loadbalancer_rservers` WHERE `device_id` = ?", array($device['device_id']));
 | 
						|
 | 
						|
foreach ($rserver_db as $serverfarm) { $serverfarms[$serverfarm['farm_id']] = $serverfarm;}
 | 
						|
 | 
						|
foreach($rserver_array as $index => $serverfarm)
 | 
						|
{
 | 
						|
 | 
						|
 $clean_index = preg_replace('@\d+\."(.*?)"\.\d+@', '\\1', $index);
 | 
						|
 | 
						|
 $oids = array (
 | 
						|
        "cesServerFarmRserverTotalConns",
 | 
						|
        "cesServerFarmRserverCurrentConns",
 | 
						|
        "cesServerFarmRserverFailedConns");
 | 
						|
 | 
						|
 $db_oids = array($clean_index => 'farm_id', "cesServerFarmRserverStateDescr" => "StateDescr");
 | 
						|
 | 
						|
 | 
						|
 if(!is_array( $serverfarms[$clean_index]))
 | 
						|
  {
 | 
						|
   $rserver_id = dbInsert(array('device_id' => $device['device_id'], 'farm_id' => $clean_index, 'StateDescr' => $serverfarm['cesServerFarmRserverStateDescr']), 'loadbalancer_rservers');
 | 
						|
  } else {
 | 
						|
    foreach($db_oids as $db_oid => $db_value) {
 | 
						|
      $db_update[$db_value] = $serverfarm[$db_oid];
 | 
						|
    }
 | 
						|
 | 
						|
    $updated   = dbUpdate($db_update, 'loadbalancer_rservers', '`rserver_id` = ?', $serverfarm['cesServerFarmRserverFailedConns']['farm_id']);
 | 
						|
  }
 | 
						|
 | 
						|
  $rrd_file = $config['rrd_dir'] . "/" . $device['hostname'] . "/rserver-".$serverfarms[$clean_index]['rserver_id'].".rrd";
 | 
						|
#echo $rrd_file."-\n";
 | 
						|
  $rrd_create = "RRA:AVERAGE:0.5:1:600 RRA:AVERAGE:0.5:6:700 RRA:AVERAGE:0.5:24:775 RRA:AVERAGE:0.5:288:797 RRA:MAX:0.5:1:600 \
 | 
						|
                    RRA:MAX:0.5:6:700 RRA:MAX:0.5:24:775 RRA:MAX:0.5:288:797";
 | 
						|
 | 
						|
  foreach ($oids as $oid)
 | 
						|
  {
 | 
						|
    $oid_ds = truncate(str_replace("cesServerFarm", "", $oid), 19, '');
 | 
						|
    $rrd_create .= " DS:$oid_ds:GAUGE:600:-1:100000000";
 | 
						|
  }
 | 
						|
 | 
						|
  $rrdupdate = "N";
 | 
						|
 | 
						|
  foreach ($oids as $oid)
 | 
						|
  {
 | 
						|
    if (is_numeric($serverfarm[$oid]))
 | 
						|
    {
 | 
						|
      $value = $serverfarm[$oid];
 | 
						|
    } else {
 | 
						|
      $value = "0";
 | 
						|
    }
 | 
						|
    $rrdupdate .= ":$value";
 | 
						|
  }
 | 
						|
 | 
						|
  if (isset($serverfarms[$clean_index]))
 | 
						|
  {
 | 
						|
    if (!file_exists($rrd_file)) { rrdtool_create($rrd_file, $rrd_create); }
 | 
						|
    rrdtool_update($rrd_file, $rrdupdate);
 | 
						|
  }
 | 
						|
 | 
						|
 | 
						|
}
 | 
						|
 | 
						|
unset($oids, $oid, $serverfarm);
 | 
						|
 | 
						|
?>
 | 
						|
 |