commit:cf07941ce4d3f44228cbc776e0c1190b2af9dc92
author:Chip Black
committer:Chip Black
date:Mon Aug 18 02:23:13 2008 -0500
parents:3cbdf79c511129ad5a6856fffdaed230469d95eb
Add check throttling in runcheckdir
diff --git a/checks/internets/check b/checks/internets/check
line changes: +1/-0
index 57bb313..d67d1aa
--- a/checks/internets/check
+++ b/checks/internets/check
@@ -1,2 +1,3 @@
 check ping -c 1 208.113.178.19
+every 600
 on change mail chip

diff --git a/runcheckdir b/runcheckdir
line changes: +16/-5
index 7dbfa2f..6b5bcca
--- a/runcheckdir
+++ b/runcheckdir
@@ -30,7 +30,7 @@ sub do_command {
 }
 
 
-my ($checkcommand, %on);
+my ($checkcommand, $every, %on);
 $on{success} = [];
 $on{failure} = [];
 $on{change} = [];
@@ -52,6 +52,8 @@ while (<CONFIG>) {
 		} else {
 			print "Unknown event in 'on', $dir/check line $.\n";
 		}
+	} elsif ($command eq 'every') {
+		$every = $words[0];
 	} else {
 		print "Unknown command '$command', $dir/check line $.\n";
 	}
@@ -68,23 +70,30 @@ unless (@{$on{failure}} || @{$on{success}} || @{$on{change}}) {
 
 open STATUS, "$dir/checkstatus";
 chomp(my $oldstatus = <STATUS>);
+my $oldtime = (stat(STATUS))[9];
 close STATUS;
 
+my $td = time() - $oldtime;
+if ($td < $every) {
+	# Not time to recheck yet
+	#print "Not rechecking; ", $every - $td, " seconds to go.\n";
+	exit $oldstatus;
+}
+
 open CHECK, '-|', $checkcommand;
 $status = <CHECK>;
 $details = join('', <CHECK>);
 close CHECK;
 my $exitstatus = $? >> 8;
 
-my $command;
 if ($exitstatus == 0 && $oldstatus != 0) {
-	do_command($command) foreach $command @{$on{success}};
+	do_command($_) foreach @{$on{success}};
 }
 if ($exitstatus != 0 && $oldstatus == 0) {
-	do_command($command) foreach $command @{$on{failure}};
+	do_command($_) foreach @{$on{failure}};
 }
 if ($exitstatus != $oldstatus) {
-	do_command($command) foreach $command @{$on{change}};
+	do_command($_) foreach @{$on{change}};
 }
 
 open STATUS, ">$dir/checkstatus";
@@ -92,3 +101,5 @@ print STATUS "$exitstatus\n";
 print STATUS "$status\n";
 print STATUS "$details\n";
 close STATUS;
+
+exit $exitstatus;