From: Dominic Hargreaves Date: Sat, 23 Mar 2013 16:09:34 +0000 (-0400) Subject: Make sure connection checks return CRITICAL rather than UNKNOWN. X-Git-Tag: 2.20.1~22 X-Git-Url: http://git.postgresql.org/gitweb/static/%7B%7Bpguslink%28?a=commitdiff_plain;h=ba280727c38be0ac815ea9e4d6dd94f85842844f;p=check_postgres.git Make sure connection checks return CRITICAL rather than UNKNOWN. Patch by Dominic Hargreaves with minor tweaks by Greg Sabino Mullane. Thanks to Christoph Berg for the forward (this came in via the Debian bugs system) --- diff --git a/check_postgres.pl b/check_postgres.pl index a3078f40d..152b7e831 100755 --- a/check_postgres.pl +++ b/check_postgres.pl @@ -2353,13 +2353,13 @@ sub run_command { $ERROR = $db->{error}; } - if ($db->{error} =~ /FATAL/) { - ## If we are just trying to connect, this should be a normal error - if ($action eq 'connection') { - $info->{fatal} = 1; - return $info; - } + ## If we are just trying to connect, failed attempts are critical + if ($action eq 'connection' and $db->{error} =~ /FATAL|could not connect/) { + $info->{fatal} = 1; + return $info; + } + if ($db->{error} =~ /FATAL/) { if (exists $arg->{fatalregex} and $db->{error} =~ /$arg->{fatalregex}/) { $info->{fatalregex} = $db->{error}; next; @@ -2369,7 +2369,7 @@ sub run_command { } } - elsif ($db->{error} =~ /statement timeout/) { + if ($db->{error} =~ /statement timeout/) { ndie msg('runcommand-timeout', $timeout); } @@ -4011,7 +4011,7 @@ sub check_connection { for $db (@{$info->{db}}) { my $err = $db->{error} || ''; - if ($err =~ /FATAL/) { + if ($err =~ /FATAL|could not connect/) { $MRTG and do_mrtg({one => 0}); add_critical $db->{error}; return;