diff options
Diffstat (limited to 'src/pmdas/dbping/dbprobe.pl')
-rw-r--r-- | src/pmdas/dbping/dbprobe.pl | 93 |
1 files changed, 93 insertions, 0 deletions
diff --git a/src/pmdas/dbping/dbprobe.pl b/src/pmdas/dbping/dbprobe.pl new file mode 100644 index 0000000..5f822dc --- /dev/null +++ b/src/pmdas/dbping/dbprobe.pl @@ -0,0 +1,93 @@ +# +# Copyright (c) 2008 Aconex. All Rights Reserved. +# Copyright (c) 2004 Silicon Graphics, Inc. All Rights Reserved. +# +# This program is free software; you can redistribute it and/or modify it +# under the terms of the GNU General Public License as published by the +# Free Software Foundation; either version 2 of the License, or (at your +# option) any later version. +# +# This program is distributed in the hope that it will be useful, but +# WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY +# or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License +# for more details. +# +# You should have received a copy of the GNU General Public License along +# with this program; if not, write to the Free Software Foundation, Inc., +# 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA +# + +use strict; +use warnings; +use DBI; +use PCP::PMDA qw(pmda_config); +use Time::HiRes qw(gettimeofday); + +my $database = 'DBI:mysql:mysql'; +my $username = 'dbmonitor'; +my $password = 'dbmonitor'; +my $response = 'SELECT 1'; +my $delay = $ARGV[0]; # delay in seconds between database ping's +$delay = 60 unless defined($delay); + +# Configuration files for overriding the above settings +for my $file ( '/etc/pcpdbi.conf', # system defaults (lowest priority) + pmda_config('PCP_PMDAS_DIR') . '/dbping/dbprobe.conf', + './dbprobe.conf' ) { # current directory (high priority) + eval `cat $file` unless ! -f $file; +} + +use vars qw( $pmda $dbh $sth ); + +sub dbping { # must return array of (response_time, status, time_stamp) + my $before; + + if (!defined($dbh)) { # reconnect if necessary + $dbh = DBI->connect($database, $username, $password, undef) || return; + $pmda->log("Connected to database.\n"); + undef $sth; + } + if (!defined($sth)) { # prepare SQL statement once only + $sth = $dbh->prepare($response) || return; + } + $before = gettimeofday; + $sth->execute || return; + while (my @row = $sth->fetchrow_array) { + ($sth->err) && return; + } + + my $timenow = localtime; + print "$timenow\t", gettimeofday - $before, "\n"; +} + +$dbh = DBI->connect($database, $username, $password, undef) || + $pmda->log("Failed initial connect: $dbh->errstr\n"); + +$| = 1; # IMPORTANT! Enables auto-flush, for piping hot pipes. +for (;;) { + dbping; + sleep($delay); +} + +=pod + +=head1 NAME + +dbprobe.pl - database response time and availability information + +=head1 SYNOPSIS + +dbprobe.pl [ delay ] + +=head1 DESCRIPTION + +The B<dbprobe.pl> utility is used by pmdadbping(1) to measure +response time from a database. A given query is executed on +the database at the requested interval (I<delay>, which defaults +to 60 seconds). This response time measure can be exported +via the Performance Co-Pilot framework for live and historical +monitoring using pmdadbping(1). + +=head1 SEE ALSO + +pmcd(1), pmdadbping(1) and DBI(3). |