--- 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."; }
|