X-Git-Url: https://git.adam-barratt.org.uk/?a=blobdiff_plain;f=dsa-nagios-checks%2Fchecks%2Fdsa-check-hpssacli;h=29826009dd99038b7f612d50f197d3f002153cda;hb=707f53188e122c957988a3370ab22887d87db1e6;hp=d10874b705df18af9daed84f3863e586898f53b4;hpb=10245f35c145c9620420b92497ce8f25725925cf;p=mirror%2Fdsa-nagios.git diff --git a/dsa-nagios-checks/checks/dsa-check-hpssacli b/dsa-nagios-checks/checks/dsa-check-hpssacli index d10874b..2982600 100755 --- a/dsa-nagios-checks/checks/dsa-check-hpssacli +++ b/dsa-nagios-checks/checks/dsa-check-hpssacli @@ -64,13 +64,14 @@ sub record($) { }; } -my $usage = "$PROGRAM_NAME: Usage: $PROGRAM_NAME [--no-battery] [--ignore-controller=] [--no-controller-ok] [--ignore-transfer-speed= [--ignore-transfer-speed= ...]]\n"; +my $usage = "$PROGRAM_NAME: Usage: $PROGRAM_NAME [--no-battery] [--ignore-cache] [--ignore-controller=] [--no-controller-ok] [--ignore-transfer-speed= [--ignore-transfer-speed= ...]]\n"; my $params; Getopt::Long::Configure('bundling'); if (!GetOptions ( '--help' => \$params->{'help'}, '--no-battery' => \$params->{'no-battery'}, '--no-controller-ok' => \$params->{'no-controller-ok'}, + '--ignore-cache' => \$params->{'ignore-cache'}, '--ignore-controller=s' => \$params->{'ignore-controller'}, '--ignore-transfer-speed=s@' => \$params->{'ignore-transfer-speed'}, )) { @@ -111,6 +112,7 @@ for my $slot (sort @controllers) { my @drives; my $nodrives = 0; my %status; + my @freetext; my $ldallshow = runcmd("controller slot=$slot ld all show"); my @logicaldrives; @@ -179,12 +181,18 @@ for my $slot (sort @controllers) { next if (/^\S.*in Slot $slot/); next if /^ *array [A-Z]$/; next if /^ *unassigned/; + if (/^ *HBA Drives/) { + # HBA mode implies no logical drives, thus reset the "drives found" check and proceed with + # checking physical drives. + $nodrives = 0; + next; + } if (/^ *(array [A-Z]) \(Failed\)$/) { record('CRITICAL'); push @{$status{'Failed'}}, $1; } elsif (/^Error: The specified controller does not have any physical drives on it.$/) { $nodrives = 1; - } elsif (/^ *physicaldrive (\S+) .* (OK|Predictive Failure|Failed|Rebuilding)(?:, (?:active )?spare)?\)$/) { + } elsif (/^ *physicaldrive (\S+) .* (OK|Predictive Failure|Failed|Rebuilding)(?:, (?:active )?spare.*)?\)$/) { my $drive = $1; my $status = $2; push @{$status{$status}}, $drive; @@ -300,12 +308,12 @@ for my $slot (sort @controllers) { next; }; - my $cst = runcmd("controller slot=$slot show status"); + my $cst = runcmd("controller slot=$slot show detail"); for (@$cst) { chomp; next if /^$/; next if (/^\S.*in Slot $slot/); - if (/^ *(.*) Status: (.*)$/) { + if (/^ *(Controller|Cache|Battery\/Capacitor) Status: (.*)$/) { my $system = $1; my $status = $2; @@ -316,19 +324,29 @@ for my $slot (sort @controllers) { # - 'Permanently Disabled' # - ...? next if $status =~ /^(OK|Not Configured)$/; + if ($params->{'ignore-cache'}) { + push @freetext, "$system: $status (ignored)"; + next; + } } - push @{$status{$status}}, $system; + push @freetext, "$system: $status"; if ($status ne 'OK') { next if ($params->{'no-battery'} && $system eq 'Battery/Capacitor'); record('WARNING'); }; - } else { - die ("Cannot read line '$_' gotten from hpssacli controller slot=$slot show status\n"); + } elsif (/^ *(Cache Status Details): (Cable Error)/) { + push @freetext, $2; + record('CRITICAL'); + } elsif (/^ *(Battery\/Capacitor Count): (.*)/) { + next if $params->{'no-battery'} || int($2) > 0; + push @freetext, "Battery count: $2"; + record('CRITICAL'); }; }; - my $status = join(" - ", (map { $_.": ".join(", ", @{$status{$_}}) } keys %status)); + my $status = join(" - ", ((map { $_.": ".join(", ", @{$status{$_}}) } keys %status), @freetext)); + push @resultstr, "Slot $slot: $status"; };