From 038ad94e108aab7cf39fd26c5fbe35699c865446 Mon Sep 17 00:00:00 2001 From: Steve Kemp Date: Wed, 14 Nov 2012 15:03:13 +0000 Subject: Added a monitor flag to alert if the queue was too high --- bin/custodian-queue | 32 ++++++++++++++++++++++++++++++-- 1 file changed, 30 insertions(+), 2 deletions(-) diff --git a/bin/custodian-queue b/bin/custodian-queue index 7eaa182..6f99896 100755 --- a/bin/custodian-queue +++ b/bin/custodian-queue @@ -5,9 +5,10 @@ # # SYNOPSIS # custodian-queu [ -h | --help ] -# [ -m | --manual] +# [ -m | --manual ] +# [ -M | --monitor ] # [ -f | --flush ] -# [ -s | --stats] +# [ -s | --stats ] # [ -S | --server 1.2.3.4:123 ] # # OPTIONS @@ -16,6 +17,8 @@ # # -m, --manual Show this manual, and exit. # +# -M, --monitor Alert, via mauve, if our queue is too full. +# # -f, --flush Flush the queue, removing all jobs. # # -s, --stats Show the pending jobs. @@ -51,17 +54,21 @@ if __FILE__ == $0 then $STATS = false $help = false $manual = false + $MONITOR = false begin opts = GetoptLong.new( [ "--flush", "-f", GetoptLong::NO_ARGUMENT ], [ "--help", "-h", GetoptLong::NO_ARGUMENT ], [ "--manual", "-m", GetoptLong::NO_ARGUMENT ], + [ "--monitor", "-M", GetoptLong::NO_ARGUMENT ], [ "--server", "-S", GetoptLong::REQUIRED_ARGUMENT ], [ "--stats", "-s", GetoptLong::NO_ARGUMENT ] ) opts.each do |opt, arg| case opt + when "--monitor": + $MONITOR = true when "--stats": $STATS = true when "--flush": @@ -113,6 +120,26 @@ if __FILE__ == $0 then # queue = Beanstalk::Pool.new([$SERVER]) + # + # Alerting on a queue that is too-full? + # + if ( $MONITOR ) + + # + # Find the number of jobs + # + stats = queue.stats() + jobs = stats['current-jobs-ready'] || 0 + + if ( jobs > 3000 ) + system( "mauvesend alert.bytemark.co.uk -i custodian -r now -s \"Our queue has #{jobs} in it\" --detail=\"

The custodian queue doesn't seem to be emptying. Is there a bug, or do we need to add more workers?

\" " ) + else + system( "mauvesend alert.bytemark.co.uk -i custodian -c now -s \"Our queue has #{jobs} in it\" --detail=\"

The custodian queue doesn't seem to be emptying. Is there a bug, or do we need to add more workers?

\" " ) + end + exit( 0 ) + end + + # # Showing stats? # @@ -122,6 +149,7 @@ if __FILE__ == $0 then exit( 0 ) end + # # Are we flushing the queue? # -- cgit v1.2.1