--- loncom/cgi/clusterstatus.pl 2003/09/01 03:37:27 1.21 +++ loncom/cgi/clusterstatus.pl 2003/09/14 18:24:34 1.22 @@ -1,7 +1,7 @@ #!/usr/bin/perl $|=1; # Generates a html page showing various sataus reports about the cluster -# $Id: clusterstatus.pl,v 1.21 2003/09/01 03:37:27 albertel Exp $ +# $Id: clusterstatus.pl,v 1.22 2003/09/14 18:24:34 www Exp $ # # Copyright Michigan State University Board of Trustees # @@ -242,6 +242,11 @@ sub announcement { print &otherwindow($local,'/announcement.txt','Announcement'); } +sub takeonline { + my $local=shift; + print &otherwindow($local,'/cgi-bin/takeonline.pl','Take online'); +} + # ========================================================= Produce a green bar sub bar { my $parm=shift; @@ -274,6 +279,11 @@ ENDHEADER print ("$trouble"); } print ""; +# re-routing + if ($host{$local.'_reroute'}) { + print "
Reroute: ".$host{$local.'_reroute'}; + &takeonline($local); + } # version if ($host{$local.'_version'}) { print "
Version: ".$host{$local.'_version'} @@ -393,6 +403,19 @@ foreach my $local (sort keys %hostname) } $host{$local.'_load'}=$userstatus{'loadavg'}; } +# -- Check reroute status + &statuslist($local,'Reroute'); + my %reroute=&replyhash($local,'/lon-status/reroute.txt',1800); + if ($reroute{'status'} eq 'rerouting') { + if ($reroute{'server'}) { + $host{$local.'_reroute'}= + 'Rerouting to '.$reroute{'server'}. + ', domain: '.$reroute{'domain'}. + ' (since '.localtime($reroute{'time'}).')'; + } else { + $host{$local.'_reroute'}='offline'; + } + } # -- Check mysql status &statuslist($local,'Database'); my %mysql=&replyhash($local,'/lon-status/mysql.txt',3600); @@ -576,6 +599,9 @@ sub reports { if ($host{$local.'_checkrpms_doomed'}>100) { $trouble='RPMs outdated.
'; } + if ($host{$local.'_reroute'}) { + $trouble='Re-Routing
'; + } if ($trouble) { $count++; &serverstatus($local,$trouble); } } unless ($count) { print "No mayor trouble."; }