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@1865 61d68cd4-352d-0410-923a-c4978735b2b8
61 lines
2.0 KiB
PHP
61 lines
2.0 KiB
PHP
<?php
|
|
|
|
$query = "SELECT * FROM sensors WHERE device_id = '" . $device['device_id'] . "' AND poller_type='ipmi'";
|
|
$ipmi_data = mysql_query($query);
|
|
|
|
if ($ipmi['host'] = get_dev_attrib($device,'ipmi_hostname'))
|
|
{
|
|
$ipmi['user'] = get_dev_attrib($device,'ipmi_username');
|
|
$ipmi['password'] = get_dev_attrib($device,'ipmi_password');
|
|
|
|
echo("Fetching IPMI sensor data...");
|
|
$results = shell_exec($config['ipmitool'] . " -c -H " . $ipmi['host'] . " -U " . $ipmi['user'] . " -P " . $ipmi['password'] . " sdr");
|
|
echo(" done.\n");
|
|
|
|
foreach (explode("\n",$results) as $row)
|
|
{
|
|
list($desc,$value,$type,$status) = explode(',',$row);
|
|
$ipmi_sensor[$desc][$ipmi_unit[$type]]['value'] = $value;
|
|
$ipmi_sensor[$desc][$ipmi_unit[$type]]['unit'] = $type;
|
|
}
|
|
|
|
while ($ipmisensors = mysql_fetch_array($ipmi_data))
|
|
{
|
|
echo("Updating IPMI sensor " . $ipmisensors['sensor_descr'] . "... ");
|
|
|
|
$sensor = $ipmi_sensor[$ipmisensors['sensor_descr']][$ipmisensors['sensor_class']]['value'];
|
|
$unit = $ipmi_sensor[$ipmisensors['sensor_descr']][$ipmisensors['sensor_class']]['unit'];
|
|
|
|
$sensorrrd = $config['rrd_dir'] . "/" . $device['hostname'] . "/" . safename($ipmisensors['sensor_class'].'-'.$ipmisensors['sensor_type'].'-'.$ipmisensors['sensor_index'] . ".rrd");
|
|
|
|
if (!is_file($sensorrrd))
|
|
{
|
|
rrdtool_create($sensorrrd,"--step 300 \
|
|
DS:sensor:GAUGE:600:-20000:20000 \
|
|
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\
|
|
RRA:MIN:0.5:1:600 \
|
|
RRA:MIN:0.5:6:700 \
|
|
RRA:MIN:0.5:24:775 \
|
|
RRA:MIN:0.5:288:797");
|
|
}
|
|
|
|
echo($sensor . " $unit\n");
|
|
|
|
rrdtool_update($sensorrrd,"N:$sensor");
|
|
|
|
## FIXME warnings in event & mail not done here yet!
|
|
|
|
mysql_query("UPDATE sensors SET sensor_current = '$sensor' WHERE poller_type='ipmi' AND sensor_class= AND sensor_id = '" . $ipmisensors['sensor_id'] . "'");
|
|
}
|
|
|
|
unset($ipmi_sensor);
|
|
}
|
|
|
|
?>
|