[nagiosplug] update check_linux_raid to take in consideration ...
Nagios Plugin Development
nagios-plugins at users.sourceforge.net
Sun Aug 18 00:50:22 CEST 2013
Module: nagiosplug
Branch: master
Commit: 130eb9635ce86a4c86d593bf5018cd4640d629c5
Author: Erwan Ben Souiden <erwan at aleikoum.net>
Committer: Holger Weiss <holger at zedat.fu-berlin.de>
Date: Tue Jun 11 11:10:49 2013 +0200
URL: http://nagiosplug.git.sf.net/git/gitweb.cgi?p=nagiosplug/nagiosplug;a=commit;h=130eb96
update check_linux_raid to take in consideration resync status and rise up a warning alert
---
contrib/check_linux_raid.pl | 15 +++++++++++++--
1 files changed, 13 insertions(+), 2 deletions(-)
diff --git a/contrib/check_linux_raid.pl b/contrib/check_linux_raid.pl
index c24b0cd..73e7fd2 100644
--- a/contrib/check_linux_raid.pl
+++ b/contrib/check_linux_raid.pl
@@ -50,6 +50,7 @@ my $code = "UNKNOWN";
my $msg = "";
my %status;
my %recovery;
+my %resyncing;
my %finish;
my %active;
my %devices;
@@ -65,6 +66,10 @@ while(defined $nextdev){
$recovery{$device} = $1;
($finish{$device}) = /finish=(.*?min)/;
$device=undef;
+ } elsif (/resync =\s+(.*?)\s/) {
+ $resyncing{$device} = $1;
+ ($finish{$device}) = /finish=(.*?min)/;
+ $device=undef;
} elsif (/^\s*$/) {
$device=undef;
}
@@ -95,8 +100,14 @@ foreach my $k (sort keys %devices){
$code = max_state($code, "CRITICAL");
}
} elsif ($status{$k} =~ /U+/) {
- $msg .= sprintf " %s status=%s.", $devices{$k}, $status{$k};
- $code = max_state($code, "OK");
+ if (defined $resyncing{$k}) {
+ $msg .= sprintf " %s status=%s, resync=%s, finish=%s.",
+ $devices{$k}, $status{$k}, $resyncing{$k}, $finish{$k};
+ $code = max_state($code, "WARNING");
+ } else {
+ $msg .= sprintf " %s status=%s.", $devices{$k}, $status{$k};
+ $code = max_state($code, "OK");
+ }
} else {
if ($active{$k}) {
$msg .= sprintf " %s active with no status information.",
More information about the Commits
mailing list