2004-02-25 14:47:27 +01:00
|
|
|
#!/usr/bin/perl -w
|
|
|
|
#
|
|
|
|
# Copyright (c) 2004 IMG SRC, Inc. All rights reserved.
|
|
|
|
#
|
2004-04-17 18:02:32 +02:00
|
|
|
# $Id: check_pgcluster.pl,v 1.4 2004/03/03 11:51:06 kuriyama Exp $
|
2004-02-25 14:47:27 +01:00
|
|
|
#
|
|
|
|
# Plugin for nagios.
|
|
|
|
#
|
|
|
|
# Prepare pgr_current_replicator() function before using.
|
|
|
|
#
|
|
|
|
# % psql -U pgsql -d template1
|
|
|
|
# template1=# create function pgr_current_replicator () returns text as 'pgr_current_replicator' language internal with (isStrict);
|
|
|
|
# CREATE FUNCTION
|
|
|
|
# template1=#
|
|
|
|
#
|
|
|
|
# define command{
|
|
|
|
# command_name check_pgcluster
|
|
|
|
# command_line $USER1$/check_pgcluster -H $HOSTADDRESS$ -p $ARG1$ -w $ARG2$
|
|
|
|
# }
|
|
|
|
#
|
|
|
|
# define service{
|
|
|
|
# use generic-service
|
|
|
|
# host_name cluster1.example.org
|
|
|
|
# service_description PGCLUSTER
|
|
|
|
# check_command check_pgcluster!5432!replicator.example.org:8777
|
|
|
|
# }
|
|
|
|
|
|
|
|
use strict;
|
|
|
|
use Getopt::Std;
|
|
|
|
use DBI;
|
|
|
|
|
2004-04-17 18:02:32 +02:00
|
|
|
my ($ret, %O, @r) = (0);
|
2004-02-25 14:47:27 +01:00
|
|
|
getopts('H:p:U:P:w:', \%O);
|
|
|
|
|
|
|
|
$O{p} ||= 5432;
|
|
|
|
$O{U} ||= "";
|
|
|
|
$O{P} ||= "";
|
|
|
|
usage() if (not $O{H} or not $O{w});
|
|
|
|
|
2004-04-17 18:02:32 +02:00
|
|
|
my $dbh = DBI->connect("dbi:Pg:dbname=template1;host=$O{H};port=$O{p}",
|
|
|
|
$O{U}, $O{P}, { PrintError => 0 });
|
2004-02-25 14:47:27 +01:00
|
|
|
|
2004-04-17 18:02:32 +02:00
|
|
|
if ($dbh) {
|
|
|
|
my $sth = $dbh->prepare("select pgr_current_replicator()") or die;
|
|
|
|
$sth->execute or die;
|
|
|
|
@r = $sth->fetchrow_array;
|
|
|
|
$sth->finish;
|
2004-02-25 14:47:27 +01:00
|
|
|
|
2004-04-17 18:02:32 +02:00
|
|
|
$dbh->disconnect;
|
2004-02-25 14:47:27 +01:00
|
|
|
|
2004-04-17 18:02:32 +02:00
|
|
|
if (not defined $r[0] or length($r[0]) < 1) {
|
|
|
|
$ret = 2;
|
|
|
|
} elsif ($r[0] ne $O{w}) {
|
|
|
|
$ret = 1;
|
|
|
|
}
|
2004-02-25 14:47:27 +01:00
|
|
|
|
2004-04-17 18:02:32 +02:00
|
|
|
} else {
|
|
|
|
$ret = 2;
|
2004-02-25 14:47:27 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
my %STATUS = (2 => "CRITICAL", 1 => "WARNING", 0 => "OK");
|
2004-04-17 18:02:32 +02:00
|
|
|
printf "PGCLUSTER %s: %s\n", $STATUS{$ret}, $r[0] || "";
|
2004-02-25 14:47:27 +01:00
|
|
|
exit $ret;
|
|
|
|
|
|
|
|
# ============================================================
|
|
|
|
sub usage {
|
|
|
|
print "Usage: check_pgcluster -H host [-p dbport] [-U dbuser] [-P dbpass] -w <primary replication server:port>\n";
|
|
|
|
exit(3);
|
|
|
|
}
|
|
|
|
|