mirror of
https://github.com/munin-monitoring/contrib.git
synced 2018-11-08 00:59:34 +01:00
191 lines
5.6 KiB
Perl
Executable File
191 lines
5.6 KiB
Perl
Executable File
#!/usr/bin/perl -w
|
|
#
|
|
# Munin plugin for MegaRAID
|
|
# This plugin can graph:- Currently Drive Temperature and Error Count
|
|
#
|
|
#---------------------
|
|
# Examples
|
|
# Create a symbolic link to MegaRaid_<AdapterNumber>_<temp|error|other|predictive>
|
|
# ln -s /usr/share/munin/plugins/MegaRaid_ /etc/munin/plugins/MegaRaid_0_temp
|
|
# graph temperature on adapter 0
|
|
#
|
|
# ln -s /usr/share/munin/plugins/MegaRaid_ /etc/munin/plugins/MegaRaid_0_error
|
|
# graph media errors on adapter 0
|
|
#
|
|
# ln -s /usr/share/munin/plugins/MegaRaid_ /etc/munin/plugins/MegaRaid_1_temp
|
|
# graph temperature on adapter 1
|
|
#
|
|
#---------------------
|
|
# Log
|
|
# Revision 0.1 2011/04/16 idobson
|
|
# -First version only basic support of the MegaRaid controller
|
|
#
|
|
# Revision 0.2 2011/04/17 fkatzenb
|
|
# -Added bash statement to remove the log file created each time MegaCli64 is ran
|
|
# -Added a few comments and visual changes
|
|
#
|
|
# Revision 1.0 2011/04/17 fkatzenb
|
|
# -Revamped Code to symbolic link for sensor type and future growth
|
|
#
|
|
# Revision 1.1 2011/04/17 fkatzenb
|
|
# -Revised scalling
|
|
#
|
|
# Revision 1.2 2011/04/28 fkatzenb
|
|
# -Added support for graph_info support
|
|
# -Added warning & critical alerts support
|
|
# -Added data info
|
|
#
|
|
# Revision 2.0 2011/04/29 fkatzenb
|
|
# -Added remaining support for SMART Errors
|
|
#
|
|
# Revision 2.1 2011/04/29 fkatzenb
|
|
# -Added version information for in the graph description
|
|
#
|
|
#
|
|
#---------------------
|
|
#
|
|
# Add the following to your /etc/munin/plugin-conf.d/munin-node:
|
|
#
|
|
# [MegaRaid_*]
|
|
# user root
|
|
#
|
|
#---------------------
|
|
#
|
|
#
|
|
# Magic markers (optional - used by munin-config and installation scripts):
|
|
#
|
|
#%# family=auto
|
|
#%# capabilities=autoconf
|
|
#
|
|
my $DisplayVer=2.1;
|
|
|
|
use strict;
|
|
use warnings;
|
|
|
|
my $DevID=0; #Device Number found
|
|
my $DevData=0; #Device Data found
|
|
|
|
# Parse out Adapter number and parameter desired from file name and remove whitespace
|
|
my $Parameters=`basename $0 | sed 's/^MegaRaid_//g' | tr '_' '-'` ;
|
|
chomp $Parameters;
|
|
my ($Adapter,$Type)=split(/-/,$Parameters);
|
|
|
|
# Locate MegaCli64 application and remove whitespace
|
|
my $Command=`which MegaCli64`;
|
|
chomp $Command;
|
|
|
|
# Use this to define future parameters to monitor
|
|
my %config = (
|
|
temp => {
|
|
lookfor => 'Drive Temperature :',
|
|
label => 'Temp',
|
|
title => "MegaRAID Adapter $Adapter: Drive Temperatures",
|
|
vlabel => 'Celsius',
|
|
graph_args => '--base 1000 -l 0',
|
|
warning => '55',
|
|
critical => '65',
|
|
info_tag => "Temperature (C)",
|
|
description => "Internal Temperatures for drives on Adapter $Adapter."
|
|
},
|
|
error => {
|
|
lookfor => 'Media Error Count: ',
|
|
label => 'Media Err',
|
|
title => "MegaRAID Adapter $Adapter: Media Errors (SMART)",
|
|
vlabel => 'Number of Errors',
|
|
graph_args => '--base 1000 -l 0',
|
|
warning => '',
|
|
critical => '',
|
|
info_tag => "Media Errors (SMART)",
|
|
description => "Number of SMART errors related to the drive's media on Adapter $Adapter."
|
|
},
|
|
other => {
|
|
lookfor => 'Other Error Count: ',
|
|
label => 'Other Err',
|
|
title => "MegaRAID Adapter $Adapter: Others Errors (SMART)",
|
|
vlabel => 'Number of Errors',
|
|
graph_args => '--base 1000 -l 0',
|
|
warning => '',
|
|
critical => '',
|
|
info_tag => "Other Errors (SMART)",
|
|
description => "Number of SMART errors not related to the drive's media on Adapter $Adapter."
|
|
},
|
|
predictive => {
|
|
lookfor => 'Predictive Failure Count: ',
|
|
label => 'Predictive Err',
|
|
title => "MegaRAID Adapter $Adapter: Predictive Errors (SMART)",
|
|
vlabel => 'Number of Errors',
|
|
graph_args => '--base 1000 -l 0',
|
|
warning => '',
|
|
critical => '',
|
|
info_tag => "Predictive Errors (SMART)",
|
|
description => "Number of SMART errors for each drive on Adapter $Adapter."
|
|
}
|
|
);
|
|
|
|
#Auto config options
|
|
if ($ARGV[0] and $ARGV[0] eq "autoconf" ) {
|
|
if (-e $Command ) {
|
|
print "yes\n";
|
|
} else {
|
|
print "no\n";
|
|
}
|
|
exit 0;
|
|
}
|
|
|
|
#Read Output of MegaRaid command
|
|
$Command.=" -PDList -a".$Adapter;
|
|
my @Output=qx($Command);
|
|
|
|
#Munin Config Options
|
|
if ($ARGV[0] and $ARGV[0] eq "config"){
|
|
print "graph_title $config{$Type}->{title}\n";
|
|
print "graph_vlabel $config{$Type}->{vlabel}\n";
|
|
print "graph_args $config{$Type}->{graph_args}\n";
|
|
print "graph_scale yes\n";
|
|
print "graph_category disk\n";
|
|
print "graph_info $config{$Type}->{description} <br />Generated by MegaRaid_, Version $DisplayVer<br />\n";
|
|
|
|
foreach my $Line (@Output) {
|
|
$Line=~ s/\r//g;
|
|
$Line=~ s/\n//g;
|
|
|
|
#Find the device ID
|
|
if ( $Line=~ m/Slot Number: /i ) {
|
|
$DevID=$Line;
|
|
$DevID=~ s/Slot Number: //;
|
|
print "A".$Adapter."_D".$DevID."_$Type.label A$Adapter:D$DevID $config{$Type}->{label}\n";
|
|
print "A".$Adapter."_D".$DevID."_$Type.info Adapter: $Adapter / Drive: $DevID - $config{$Type}->{info_tag}\n";
|
|
if ($config{$Type}->{warning} ne '' ) {
|
|
print "A".$Adapter."_D".$DevID."_$Type.warning $config{$Type}->{warning}\n";
|
|
}
|
|
if ($config{$Type}->{critical} ne '') {
|
|
print "A".$Adapter."_D".$DevID."_$Type.critical $config{$Type}->{critical}\n";
|
|
}
|
|
}
|
|
}
|
|
exit 0;
|
|
}
|
|
|
|
#Actually dump the data
|
|
foreach my $Line (@Output) {
|
|
$Line=~ s/\r//g;
|
|
$Line=~ s/\n//g;
|
|
|
|
#Find the device ID
|
|
if ( $Line=~ m/Slot Number: /i ) { $DevID=$Line; $DevID=~ s/Slot Number: //; chomp $DevID; }
|
|
|
|
#Find the data and print it out
|
|
if ( $Line=~ m/$config{$Type}->{lookfor}/i ) {
|
|
$DevData=$Line;
|
|
$DevData=~s/$config{$Type}->{lookfor}//;
|
|
$DevData=~s/C.*//;
|
|
chomp $DevData;
|
|
print "A".$Adapter."_D".$DevID."_$Type.value $DevData\n";
|
|
}
|
|
}
|
|
|
|
#Remove log file created by running MegaCli
|
|
unlink "MegaSAS.log";
|
|
|
|
exit 0;
|