New plugin: check_sensors
Richard Colley
rcolley at cardaccess.com.au
Thu Jan 16 01:17:16 CET 2003
I've got a simple perl script for checking CPU temp and any other variable
output by the lm_sensors package. But it doesn't really conform to the
Nagios plugin guidelines. I'd be really happy if anyone was interested in
making it conform. Unfortunately, I don't have the time to do this. Feel
free to use it anyway.
The general usage is:
check_sensors <chip> <field1> <disp1> <warn1> <crit1> ....
'field1' is the name of the field output by 'sensors'.
'disp1' is what to print back to nagios as the name of this field.
'warn1' is an expression that defines when a warning will be generated for
this field
'crit1' is an expression that defines when a critical will be generated for
this field
The 'warn1' and 'crit1' values can be numbers e.g. '35.5' or expressions
e.g. '<20'. No attempt is made to ensure the warning and critical
expressions are logically consistent.
Output is a single line with the values of each of the sensor checks
requested, and an indication if they are above the critical or warning
thresholds.
An example:
check_sensors via686a-isa-0c00 'CPU Temp' 'CPU Temp' 38 42 'SYS
Temp' 'SYS Temp' 30 35 'CPU core' 'CPU core' '<=1.80' '<1.79' 'CPU Fan' 'CPU
Fan' '<3500' '<3000'
... Generates a warning if CPU temp >=38, and critical if >=42 ... Generates
a warning if SYS temp >=30, and critical if >=35 ... Generates a warning if
CPU core V <=1.80, and critical if <1.79 ... Generates a warning if CPU fan
RPM <3500, and critical if <3000
The output generated for the above would be something like:
CPU core=1.67(C<1.79):CPU Fan=5625:SYS Temp=30.1:CPU Temp=34.3:
An obvious extension is to use nagios performance data logging output
format. But alas, no time ;-}
Feel free to email with questions. (Please - no flames on my poor Perl
coding - I know it's bad :-)
Richard
---------------- check_sensors
#!/usr/bin/env perl
#
# check sensors according to lm_sensors output
#
# (c)2003 Richard Colley <Richard.Colley at rcolley.com>
# License: GPL v2
#
#### Some paths
$SENSOR_PROG="/usr/local/bin/sensors";
###################
$progname=$0;
$RC_OK=0;
$RC_WARN=1;
$RC_CRITICAL=2;
sub usage {
my ($msg) = shift;
print "$msg\n";
print "Usage: $progname <chip> <field1> <disp1> <warn threshold1>
<critical threshold1> ...\n";
print "\twhere:\t<chip> corresponds to an entry in
/etc/sensors.conf\n";
print "\t\t<field1> is the name of a field output by 'sensors'\n";
print "\t\t<disp1> is a string to use while displaying this
field\n";
print "\t\t<warn threshold1> is the warning threshold value of the
field output by 'sensors'\n";
print "\t\t<critical threshold1> is the critical threshold value of
the field output by 'sensors'\n";
print "\t\tmultiple triples are permitted\n";
print "\n\t\tNB: a threshold value can be optionally prefixed by an
operator character.\n";
print "\t\tValid operators are currently '>', '<', '==', '>=', '<='.
The default is '>='.\n";
print "\t\t\te.g. if the warn threshold is <30, then a warning is
raised if the value is less than 30.\n";
print "\t\tNo attempt is made to ensure the resultant logic is
sensible\n";
exit $RC_CRITICAL;
}
if( $#ARGV < 4 ) {
usage "Not enough args";
}
$chip=$ARGV[0];
shift @ARGV;
%fields={};
while( $#ARGV >= 3 ) {
$i=0;
$field=$ARGV[$i];
$i++;
$fieldDisp=$ARGV[$i];
$i++;
$ARGV[$i] =~ /^([=<>]*)([0-9.]+)/ or usage "Invalid warning
threshold format: $ARGV[$i]";
$warn = $2;
$warnop = $1 ne "" ? $1 : ">=";
$i++;
$ARGV[$i] =~ /^([=<>]*)([0-9.]+)/ or usage "Invalid critical
threshold format: $ARGV[$i]";
$critical = $2;
$criticalop = $1 ne "" ? $1 : ">=";
$i++;
$config{ $field } = [ $fieldDisp, $warn, $warnop, $critical,
$criticalop ];
shift @ARGV;
shift @ARGV;
shift @ARGV;
shift @ARGV;
}
sub eval_simple {
my( $value, $op, $threshold ) = @_;
eval "$value $op $threshold";
}
$output="";
$retcode = $RC_OK;
open( SENSOR, "$SENSOR_PROG $chip|" ) or usage "Failed to run
$SENSOR_PROG\n"; while( <SENSOR> ) {
if( /^([^:]+)[^0-9]*([0-9.]+)/ ) {
$field = $1;
$value = $2;
if( defined( $config{ $field } ) ) {
$fieldDisp = ${$config{ $field }}[0];
$warn = ${$config{ $field }}[1];
$warnop = ${$config{ $field }}[2];
$critical = ${$config{ $field }}[3];
$criticalop = ${$config{ $field }}[4];
$output .= "$fieldDisp=$value";
if( eval_simple( $value, $criticalop, $critical ) )
{
$output .= "(C$criticalop$critical)";
$retcode = $RC_CRITICAL;
} elsif( $retcode == $RC_OK and eval_simple( $value,
$warnop, $warn ) ) {
$output .= "(W$warnop$warn)";
$retcode = $RC_WARN;
}
$output .= ";";
}
}
}
close( SENSOR );
print "$output\n";
exit $retcode;
---
Outgoing mail is certified Virus Free.
Checked by AVG anti-virus system (http://www.grisoft.com).
Version: 6.0.443 / Virus Database: 248 - Release Date: 10/01/2003
-------------------------------------------------------
This SF.NET email is sponsored by: FREE SSL Guide from Thawte are you
planning your Web Server Security? Click here to get a FREE Thawte SSL guide
and find the answers to all your SSL security issues.
http://ads.sourceforge.net/cgi-bin/redirect.pl?thaw0026en
_______________________________________________
Nagiosplug-devel mailing list Nagiosplug-devel at lists.sourceforge.net
https://lists.sourceforge.net/lists/listinfo/nagiosplug-devel
---
Incoming mail is certified Virus Free.
Checked by AVG anti-virus system (http://www.grisoft.com).
Version: 6.0.443 / Virus Database: 248 - Release Date: 10/01/2003
I've got a simple perl script for checking CPU temp and any other variable
output by the lm_sensors package. But it doesn't really conform to the
Nagios plugin guidelines. I'd be really happy if anyone was interested in
making it conform. Unfortunately, I don't have the time to do this. Feel
free to use it anyway.
The general usage is:
check_sensors <chip> <field1> <disp1> <warn1> <crit1> ....
'field1' is the name of the field output by 'sensors'.
'disp1' is what to print back to nagios as the name of this field. 'warn1'
is an expression that defines when a warning will be generated for this
field 'crit1' is an expression that defines when a critical will be
generated for this field
The 'warn1' and 'crit1' values can be numbers e.g. '35.5' or expressions
e.g. '<20'. No attempt is made to ensure the warning and critical
expressions are logically consistent.
Output is a single line with the values of each of the sensor checks
requested, and an indication if they are above the critical or warning
thresholds.
An example:
check_sensors via686a-isa-0c00 'CPU Temp' 'CPU Temp' 38 42 'SYS
Temp' 'SYS Temp' 30 35 'CPU core' 'CPU core' '<=1.80' '<1.79' 'CPU Fan' 'CPU
Fan' '<3500' '<3000'
... Generates a warning if CPU temp >=38, and critical if >=42 ... Generates
a warning if SYS temp >=30, and critical if >=35 ... Generates a warning if
CPU core V <=1.80, and critical if <1.79 ... Generates a warning if CPU fan
RPM <3500, and critical if <3000
The output generated for the above would be something like:
CPU core=1.67(C<1.79):CPU Fan=5625:SYS Temp=30.1:CPU Temp=34.3:
An obvious extension is to use nagios performance data logging output
format. But alas, no time ;-}
Feel free to email with questions. (Please - no flames on my poor Perl
coding - I know it's bad :-)
Richard
---------------- check_sensors
#!/usr/bin/env perl
#
# check sensors according to lm_sensors output
#
# (c)2003 Richard Colley <Richard.Colley at rcolley.com>
# License: GPL v2
#
#### Some paths
$SENSOR_PROG="/usr/local/bin/sensors";
###################
$progname=$0;
$RC_OK=0;
$RC_WARN=1;
$RC_CRITICAL=2;
sub usage {
my ($msg) = shift;
print "$msg\n";
print "Usage: $progname <chip> <field1> <disp1> <warn threshold1>
<critical threshold1> ...\n";
print "\twhere:\t<chip> corresponds to an entry in
/etc/sensors.conf\n";
print "\t\t<field1> is the name of a field output by 'sensors'\n";
print "\t\t<disp1> is a string to use while displaying this
field\n";
print "\t\t<warn threshold1> is the warning threshold value of the
field output by 'sensors'\n";
print "\t\t<critical threshold1> is the critical threshold value of
the field output by 'sensors'\n";
print "\t\tmultiple triples are permitted\n";
print "\n\t\tNB: a threshold value can be optionally prefixed by an
operator character.\n";
print "\t\tValid operators are currently '>', '<', '==', '>=', '<='.
The default is '>='.\n";
print "\t\t\te.g. if the warn threshold is <30, then a warning is
raised if the value is less than 30.\n";
print "\t\tNo attempt is made to ensure the resultant logic is
sensible\n";
exit $RC_CRITICAL;
}
if( $#ARGV < 4 ) {
usage "Not enough args";
}
$chip=$ARGV[0];
shift @ARGV;
%fields={};
while( $#ARGV >= 3 ) {
$i=0;
$field=$ARGV[$i];
$i++;
$fieldDisp=$ARGV[$i];
$i++;
$ARGV[$i] =~ /^([=<>]*)([0-9.]+)/ or usage "Invalid warning
threshold format: $ARGV[$i]";
$warn = $2;
$warnop = $1 ne "" ? $1 : ">=";
$i++;
$ARGV[$i] =~ /^([=<>]*)([0-9.]+)/ or usage "Invalid critical
threshold format: $ARGV[$i]";
$critical = $2;
$criticalop = $1 ne "" ? $1 : ">=";
$i++;
$config{ $field } = [ $fieldDisp, $warn, $warnop, $critical,
$criticalop ];
shift @ARGV;
shift @ARGV;
shift @ARGV;
shift @ARGV;
}
sub eval_simple {
my( $value, $op, $threshold ) = @_;
eval "$value $op $threshold";
}
$output="";
$retcode = $RC_OK;
open( SENSOR, "$SENSOR_PROG $chip|" ) or usage "Failed to run
$SENSOR_PROG\n"; while( <SENSOR> ) {
if( /^([^:]+)[^0-9]*([0-9.]+)/ ) {
$field = $1;
$value = $2;
if( defined( $config{ $field } ) ) {
$fieldDisp = ${$config{ $field }}[0];
$warn = ${$config{ $field }}[1];
$warnop = ${$config{ $field }}[2];
$critical = ${$config{ $field }}[3];
$criticalop = ${$config{ $field }}[4];
$output .= "$fieldDisp=$value";
if( eval_simple( $value, $criticalop, $critical ) )
{
$output .= "(C$criticalop$critical)";
$retcode = $RC_CRITICAL;
} elsif( $retcode == $RC_OK and eval_simple( $value,
$warnop, $warn ) ) {
$output .= "(W$warnop$warn)";
$retcode = $RC_WARN;
}
$output .= ";";
}
}
}
close( SENSOR );
print "$output\n";
exit $retcode;
---
Outgoing mail is certified Virus Free.
Checked by AVG anti-virus system (http://www.grisoft.com).
Version: 6.0.443 / Virus Database: 248 - Release Date: 10/01/2003
-------------------------------------------------------
This SF.NET email is sponsored by: A Thawte Code Signing Certificate
is essential in establishing user confidence by providing assurance of
authenticity and code integrity. Download our Free Code Signing guide:
http://ads.sourceforge.net/cgi-bin/redirect.pl?thaw0028en
More information about the Users
mailing list