Fix pacemaker ignore action... Should work at last....

This commit is contained in:
Quentin Garnier 2014-09-30 17:38:42 +02:00
parent 7cf97234f5
commit 280f9fce61
1 changed files with 18 additions and 14 deletions

View File

@ -93,7 +93,8 @@ sub parse_output {
my @standby; my @standby;
$self->{output}->output_add(severity => 'OK', $self->{output}->output_add(severity => 'OK',
short_msg => "Cluster is OK"); short_msg => "Cluster is OK");
foreach my $line (split /\n/, $options{crm_out}) { my @lines = split /\n/, $options{crm_out};
foreach my $line (shift @lines) {
if ($line =~ /Connection to cluster failed\:(.*)/i ) { if ($line =~ /Connection to cluster failed\:(.*)/i ) {
$self->{output}->output_add(severity => 'CRITICAL', $self->{output}->output_add(severity => 'CRITICAL',
short_msg => "Connection to cluster FAILED: $1"); short_msg => "Connection to cluster FAILED: $1");
@ -125,26 +126,29 @@ sub parse_output {
$self->{output}->output_add(severity => $self->{threshold}, $self->{output}->output_add(severity => $self->{threshold},
short_msg => "$1 Stopped"); short_msg => "$1 Stopped");
} elsif ($line =~ /^Failed actions\:/) { } elsif ($line =~ /^Failed actions\:/) {
# Check Failed Actions # Check Failed Actions
my $skip = 0; my $error = 0;
foreach (@{$self->{option_results}->{ignore_failed_actions}}) { foreach my $line_failed_action (shift @lines) {
if ($line =~ /$_/) { my $skip = 0;
$skip = 1; foreach (@{$self->{option_results}->{ignore_failed_actions}}) {
if ($line_failed_action =~ /$_/) {
$skip = 1;
last;
}
}
if ($skip == 0) {
$error = 1;
last; last;
} }
} }
next if ($skip == 1); if ($error == 1) {
$self->{output}->output_add(severity => 'CRITICAL',
$self->{output}->output_add(severity => 'CRITICAL', short_msg => "FAILED actions detected or not cleaned up");
short_msg => "FAILED actions detected or not cleaned up"); }
} elsif ($line =~ /\s*(\S+?)\s+ \(.*\)\:\s+\w+\s+\w+\s+\(unmanaged\)\s+FAILED/) { } elsif ($line =~ /\s*(\S+?)\s+ \(.*\)\:\s+\w+\s+\w+\s+\(unmanaged\)\s+FAILED/) {
# Check Unmanaged # Check Unmanaged
$self->{output}->output_add(severity => 'CRITICAL', $self->{output}->output_add(severity => 'CRITICAL',
short_msg => "$1 unmanaged FAILED"); short_msg => "$1 unmanaged FAILED");
} elsif ($line =~ /\s*(\S+?)\s+ \(.*\)\:\s+not installed/i) {
# Check for errors
$self->{output}->output_add(severity => 'CRITICAL',
short_msg => "$1 not installed");
} elsif ($line =~ /\s*(\S+?):.*(fail-count=\d+)/i) { } elsif ($line =~ /\s*(\S+?):.*(fail-count=\d+)/i) {
# Check for resource Fail count # Check for resource Fail count
$self->{output}->output_add(severity => 'WARNING', $self->{output}->output_add(severity => 'WARNING',