aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorGravatar Subhendu Ghosh <sghosh@users.sourceforge.net> 2002-09-04 02:12:05 +0000
committerGravatar Subhendu Ghosh <sghosh@users.sourceforge.net> 2002-09-04 02:12:05 +0000
commit91c089475cc8be8531a6f19f2a30a9f0c641e489 (patch)
tree1acdb3ca32e614e266a3226b41f1a97b43765604
parent4a079cf372ddfaaa80ad3843ce7c9a0c5e2700da (diff)
downloadmonitoring-plugins-91c089475cc8be8531a6f19f2a30a9f0c641e489.tar.gz
dispersion check now controlled by warn and crit
git-svn-id: https://nagiosplug.svn.sourceforge.net/svnroot/nagiosplug/nagiosplug/trunk@90 f882894a-f735-0410-b71e-b25c423dba1c
-rwxr-xr-xplugins-scripts/check_ntp.pl27
1 files changed, 15 insertions, 12 deletions
diff --git a/plugins-scripts/check_ntp.pl b/plugins-scripts/check_ntp.pl
index fee58e69..dce515ef 100755
--- a/plugins-scripts/check_ntp.pl
+++ b/plugins-scripts/check_ntp.pl
@@ -76,8 +76,8 @@ GetOptions
("V" => \$opt_V, "version" => \$opt_V,
"h" => \$opt_h, "help" => \$opt_h,
"v" => \$verbose, "verbose" => \$verbose,
- "w=s" => \$opt_w, "warning=s" => \$opt_w, # offset|adjust warning if above this number
- "c=s" => \$opt_c, "critical=s" => \$opt_c, # offset|adjust critical if above this number
+ "w=f" => \$opt_w, "warning=f" => \$opt_w, # offset|adjust warning if above this number
+ "c=f" => \$opt_c, "critical=f" => \$opt_c, # offset|adjust critical if above this number
"H=s" => \$opt_H, "hostname=s" => \$opt_H);
if ($opt_V) {
@@ -98,13 +98,14 @@ unless ($host) {
exit $ERRORS{'UNKNOWN'};
}
-($opt_w) || ($opt_w = shift) || ($opt_w = 60);
-my $warning = $1 if ($opt_w =~ /([0-9]+)/);
+($opt_w) || ($opt_w = 60);
+my $warning = $1 if ($opt_w =~ /([0-9.]+)/);
-($opt_c) || ($opt_c = shift) || ($opt_c = 120);
-my $critical = $1 if ($opt_c =~ /([0-9]+)/);
+($opt_c) || ($opt_c = 120);
+my $critical = $1 if ($opt_c =~ /([0-9.]+)/);
-if ($opt_c < $opt_w) {
+
+if ($critical < $warning ) {
print "Critical offset should be larger than warning offset\n";
print_usage();
exit $ERRORS{"UNKNOWN"};
@@ -189,11 +190,11 @@ if ($have_ntpdc) {
while (<NTPDC>) {
print $_ if ($verbose);
if (/([^\s]+)\s+([-0-9.]+)\s+([-0-9.]+)\s+([-0-9.]+)\s+([-0-9.]+)\s+([-0-9.]+)\s+([-0-9.]+)\s+([-0-9.]+)/) {
- if ($8>15) {
- print "Dispersion = $8 \n" if ($verbose);
+ if ($8 gt $critical) {
+ print "Dispersion_crit = $8 :$critical\n" if ($verbose);
$dispersion_error = $ERRORS{'CRITICAL'};
- } elsif ($8>5 && $dispersion_error<$ERRORS{'CRITICAL'}) {
- print "Dispersion = $8 \n" if ($verbose);
+ } elsif ($8 gt $warning ) {
+ print "Dispersion_warn = $8 :$warning \n" if ($verbose);
$dispersion_error = $ERRORS{'WARNING'};
} else {
$dispersion_error = $ERRORS{'OK'};
@@ -252,7 +253,7 @@ foreach $key (keys %ERRORS) {
exit $state;
sub print_usage () {
- print "Usage: $PROGNAME -H <host> [-w <warn>] [-c <crit>]\n";
+ print "Usage: $PROGNAME -H <host> [-w <warn>] [-c <crit>] [-v verbose]\n";
}
sub print_help () {
@@ -263,5 +264,7 @@ sub print_help () {
print "\n";
print "<warn> = Clock offset in seconds at which a warning message will be generated.\n Defaults to 60.\n";
print "<crit> = Clock offset in seconds at which a critical message will be generated.\n Defaults to 120.\n\n";
+ print "The same warning and critical values are used to check against the dispersion \n";
+ print "column of ntpdc/xntpdc for the host being queried.\n\n";
support();
}