--- loncom/loncron 2003/04/07 18:19:23 1.38 +++ loncom/loncron 2003/10/14 15:36:21 1.44 @@ -49,6 +49,133 @@ sub errout { ENDERROUT } +sub start_daemon { + my ($fh,$daemon,$pidfile) = @_; + my $progname=$daemon; + if ($daemon eq 'lonc' && $ARGV[0] eq 'new') { + $progname='loncnew'; + print "new "; + } + system("$perlvar{'lonDaemons'}/$progname 2>>$perlvar{'lonDaemons'}/logs/${daemon}_errors"); + sleep 2; + if (-e $pidfile) { + print $fh "Seems like it started ...
"; + my $lfh=IO::File->new("$pidfile"); + my $daemonpid=<$lfh>; + chomp($daemonpid); + sleep 2; + if (kill 0 => $daemonpid) { + return 1; + } else { + return 0; + } + } + print $fh "Seems like that did not work!
"; + $errors++; + return 0; +} + +sub checkon_daemon { + my ($fh,$daemon,$maxsize,$sendusr1)=@_; + + print $fh '
'; + printf("%-10s ",$daemon); + if (-e "$perlvar{'lonDaemons'}/logs/$daemon.log"){ + open (DFH,"tail -n25 $perlvar{'lonDaemons'}/logs/$daemon.log|"); + while ($line="; + + my $pidfile="$perlvar{'lonDaemons'}/logs/$daemon.pid"; + + my $restartflag=1; + + if (-e $pidfile) { + my $lfh=IO::File->new("$pidfile"); + my $daemonpid=<$lfh>; + chomp($daemonpid); + if (kill 0 => $daemonpid) { + print $fh ") { + print $fh "$line"; + if ($line=~/INFO/) { $notices++; } + if ($line=~/WARNING/) { $notices++; } + if ($line=~/CRITICAL/) { $warnings++; } + }; + close (DFH); + } + print $fh "
"; + print " "; + if (&start_daemon($fh,$daemon,$pidfile)) { + print $fh "
"; + } + } + + if (-e "$perlvar{'lonDaemons'}/logs/$daemon.log"){ + print $fh "
"; + open (DFH,"tail -n100 $perlvar{'lonDaemons'}/logs/$daemon.log|"); + while ($line="; + } + } + + $fname="$perlvar{'lonDaemons'}/logs/$daemon.log"; + + my ($dev,$ino,$mode,$nlink, + $uid,$gid,$rdev,$size, + $atime,$mtime,$ctime, + $blksize,$blocks)=stat($fname); + + if ($size>$maxsize) { + print $fh "Rotating logs ...) { + print $fh "$line"; + if ($line=~/WARNING/) { $notices++; } + if ($line=~/CRITICAL/) { $notices++; } + }; + close (DFH); + print $fh "
";
+ rename("$fname.2","$fname.3");
+ rename("$fname.1","$fname.2");
+ rename("$fname","$fname.1");
+ }
+
+ &errout($fh);
+}
# ================================================================ Main Program
# --------------------------------- Read loncapa_apache.conf and loncapa.conf
@@ -61,13 +188,13 @@ delete $perlvar{'lonSqlAccess'}; # remov
# --------------------------------------- Make sure that LON-CAPA is configured
# I only test for one thing here (lonHostID). This is just a safeguard.
if ('{[[[[lonHostID]]]]}' eq $perlvar{'lonHostID'}) {
- print("Unconfigured machine.\n");
- $emailto=$perlvar{'lonSysEMail'};
- $hostname=`/bin/hostname`;
- chop $hostname;
- $hostname=~s/[^\w\.]//g; # make sure is safe to pass through shell
- $subj="LON: Unconfigured machine $hostname";
- system("echo 'Unconfigured machine $hostname.' |\
+ print("Unconfigured machine.\n");
+ $emailto=$perlvar{'lonSysEMail'};
+ $hostname=`/bin/hostname`;
+ chop $hostname;
+ $hostname=~s/[^\w\.]//g; # make sure is safe to pass through shell
+ $subj="LON: Unconfigured machine $hostname";
+ system("echo 'Unconfigured machine $hostname.' |\
mailto $emailto -s '$subj' > /dev/null");
exit 1;
}
@@ -75,18 +202,18 @@ if ('{[[[[lonHostID]]]]}' eq $perlvar{'l
# ----------------------------- Make sure this process is running from user=www
my $wwwid=getpwnam('www');
if ($wwwid!=$<) {
- print("User ID mismatch. This program must be run as user 'www'\n");
- $emailto="$perlvar{'lonAdmEMail'},$perlvar{'lonSysEMail'}";
- $subj="LON: $perlvar{'lonHostID'} User ID mismatch";
- system("echo 'User ID mismatch. loncron must be run as user www.' |\
+ print("User ID mismatch. This program must be run as user 'www'\n");
+ $emailto="$perlvar{'lonAdmEMail'},$perlvar{'lonSysEMail'}";
+ $subj="LON: $perlvar{'lonHostID'} User ID mismatch";
+ system("echo 'User ID mismatch. loncron must be run as user www.' |\
mailto $emailto -s '$subj' > /dev/null");
- exit 1;
+ exit 1;
}
# ------------------------------------------------------------- Read hosts file
{
my $config=IO::File->new("$perlvar{'lonTabDir'}/hosts.tab");
-
+
while (my $configline=<$config>) {
my ($id,$domain,$role,$name,$ip,$domdescr)=split(/:/,$configline);
if ($id && $domain && $role && $name && $ip) {
@@ -109,12 +236,12 @@ if ($wwwid!=$<) {
# ------------------------------------------------------ Read spare server file
{
my $config=IO::File->new("$perlvar{'lonTabDir'}/spare.tab");
-
+
while (my $configline=<$config>) {
- chomp($configline);
- if (($configline) && ($configline ne $perlvar{'lonHostID'})) {
- $spareid{$configline}=1;
- }
+ chomp($configline);
+ if (($configline) && ($configline ne $perlvar{'lonHostID'})) {
+ $spareid{$configline}=1;
+ }
}
}
@@ -130,9 +257,10 @@ $now=time;
$date=localtime($now);
{
-my $fh=IO::File->new(">$statusdir/newstatus.html");
-
-print $fh (< Cleaned up ".$cleaned." stale session token(s).";
-print $fh " ";
- my $lfh=IO::File->new("$lonsqlfile");
- my $lonsqlpid=<$lfh>;
- chomp($lonsqlpid);
- sleep 2;
- if (kill 0 => $lonsqlpid) {
- print $fh " ";
- system(
- "$perlvar{'lonDaemons'}/lonsql 2>>$perlvar{'lonDaemons'}/logs/lonsql_errors");
- sleep 2;
+ if ($since>365*$perlvar{'lonExpire'}) {
+ $cleaned++;
+ unlink("$fname");
+ } else { $old++; }
}
- } else {
- print $fh "Seems like that did not work! ";
- $errors++;
- }
- if (-e "$perlvar{'lonDaemons'}/logs/lonsql.log"){
- print $fh " ";
- rename("$fname.2","$fname.3");
- rename("$fname.1","$fname.2");
- rename("$fname","$fname.1");
}
+ print $fh " Cleaned up ".$cleaned." stale session token(s).";
+ print $fh " ";
- my $lfh=IO::File->new("$londfile");
- my $londpid=<$lfh>;
- chomp($londpid);
- sleep 2;
- if (kill 0 => $londpid) {
- print $fh " ";
- system(
- "$perlvar{'lonDaemons'}/lond 2>>$perlvar{'lonDaemons'}/logs/lond_errors");
- sleep 2;
- }
- } else {
- print $fh "Seems like that did not work! ";
- $errors++;
- }
- if (-e "$perlvar{'lonDaemons'}/logs/lond.log"){
- print $fh " ";
- rename("$fname.2","$fname.3");
- rename("$fname.1","$fname.2");
- rename("$fname","$fname.1");
-}
-&errout($fh);
-# ------------------------------------------------------------------------ lonc
+# ---------------------------------------------------------------------- lonsql
-print $fh ' ";
- my $lfh=IO::File->new("$loncfile");
- my $loncpid=<$lfh>;
- chomp($loncpid);
- sleep 2;
- if (kill 0 => $loncpid) {
- print $fh " ";
- system(
- "$perlvar{'lonDaemons'}/lonc 2>>$perlvar{'lonDaemons'}/logs/lonc_errors");
- sleep 2;
- }
- } else {
- print $fh "Seems like that did not work! ";
- $errors++;
- }
- if (-e "$perlvar{'lonDaemons'}/logs/lonc.log") {
- print $fh " ";
- rename("$fname.2","$fname.3");
- rename("$fname.1","$fname.2");
- rename("$fname","$fname.1");
-}
+ &checkon_daemon($fh,'lonc',40000,1);
-
-&errout($fh);
# -------------------------------------------------------------------- lonhttpd
-print $fh ' ";
- my $lfh=IO::File->new("$lonhttpdfile");
- my $lonhttpdpid=<$lfh>;
- chomp($lonhttpdpid);
- sleep 2;
- if (kill 0 => $lonhttpdpid) {
- print $fh " ";
- system(
- "$perlvar{'lonDaemons'}/lonhttpd 2>>$perlvar{'lonDaemons'}/logs/lonhttpd_errors");
- sleep 2;
- }
- } else {
- print $fh "Seems like that did not work! ";
- $errors++;
- }
- if (-e "$perlvar{'lonDaemons'}/logs/lonhttpd.log") {
- print $fh " ";
- rename("$fname.2","$fname.3");
- rename("$fname.1","$fname.2");
- rename("$fname","$fname.1");
-}
+ print $fh ' ";
- rename("$fname.2","$fname.3");
- rename("$fname.1","$fname.2");
- rename("$fname","$fname.1");
-}
+ if ($size>40000) {
+ print $fh "Rotating logs ... ";
+ rename("$fname.2","$fname.3");
+ rename("$fname.1","$fname.2");
+ rename("$fname","$fname.1");
+ }
-print $fh " \n";
-$warnings=$warnings+5*$unsend;
+ print $fh "Total unsend messages: $unsend \n";
+ $warnings=$warnings+5*$unsend;
-print $fh " \n";
-}
-print $fh "$varname $perlvar{$varname} Hosts
";
-foreach $id (sort(keys(%hostname))) {
- print $fh
- "
\n";
-}
-print $fh "$id $hostdom{$id} $hostrole{$id} ";
- print $fh "$hostname{$id} $hostip{$id} Spare Hosts
";
-foreach $id (sort(keys(%spareid))) {
- print $fh "
\n";
+ foreach $varname (sort(keys(%perlvar))) {
+ print $fh " \n";
+ }
+ print $fh "$varname $perlvar{$varname} Hosts
";
+ foreach $id (sort(keys(%hostname))) {
+ print $fh
+ "
\n";
+ }
+ print $fh "$id $hostdom{$id} $hostrole{$id} ";
+ print $fh "$hostname{$id} $hostip{$id} Spare Hosts
";
+ foreach $id (sort(keys(%spareid))) {
+ print $fh "
\n";
# --------------------------------------------------------------------- Machine
-
-print $fh 'Machine Information
';
-print $fh "loadavg
";
-
-open (LOADAVGH,"/proc/loadavg");
-$loadavg=df
";
-print $fh "";
-
-open (DFH,"df|");
-while ($line=
";
-
-
-print $fh "ps
";
-print $fh "";
-$psproc=0;
-
-open (PSH,"ps -aux|");
-while ($line=
";
-
-if ($psproc>200) { $notices++; }
-if ($psproc>250) { $notices++; }
-
-&errout($fh);
-
-# --------------------------------------------------------------- clean out tmp
-print $fh 'Temporary Files
';
-$cleaned=0;
-$old=0;
-while ($fname=<$perlvar{'lonDaemons'}/tmp/*>) {
- my ($dev,$ino,$mode,$nlink,
- $uid,$gid,$rdev,$size,
- $atime,$mtime,$ctime,
- $blksize,$blocks)=stat($fname);
- $now=time;
- $since=$now-$mtime;
- if ($since>$perlvar{'lonExpire'}) {
- $line='';
- if (open(PROBE,$fname)) {
- $line=Session Tokens
';
-$cleaned=0;
-$active=0;
-while ($fname=<$perlvar{'lonIDsDir'}/*>) {
- my ($dev,$ino,$mode,$nlink,
- $uid,$gid,$rdev,$size,
- $atime,$mtime,$ctime,
- $blksize,$blocks)=stat($fname);
- $now=time;
- $since=$now-$mtime;
- if ($since>$perlvar{'lonExpire'}) {
- $cleaned++;
- print $fh "Unlinking $fname
";
- unlink("$fname");
- } else {
- $active++;
- }
+ print $fh 'Machine Information
';
+ print $fh "loadavg
";
-}
-print $fh "$active open session(s)
";
+ open (LOADAVGH,"/proc/loadavg");
+ $loadavg=df
";
+ print $fh "";
-print $fh '
httpd
Access Log
';
+ open (DFH,"df|");
+ while ($line=
";
-open (DFH,"tail -n25 /etc/httpd/logs/access_log|");
-while ($line=Error Log
";
-
-open (DFH,"tail -n25 /etc/httpd/logs/error_log|");
-while ($line=
";
-&errout($fh);
+ print $fh "ps
";
+ print $fh "";
+ $psproc=0;
+
+ open (PSH,"ps -aux|");
+ while ($line=
";
-# ---------------------------------------------------------------------- lonsql
+ if ($psproc>200) { $notices++; }
+ if ($psproc>250) { $notices++; }
-my $restartflag=1;
-if ($perlvar{'lonRole'} eq "library") {
+ &errout($fh);
- print $fh 'lonsql
Log
';
- print "lonsql\n";
- if (-e "$perlvar{'lonDaemons'}/logs/lonsql.log"){
- open (DFH,"tail -n100 $perlvar{'lonDaemons'}/logs/lonsql.log|");
- while ($line=
";
-
- my $lonsqlfile="$perlvar{'lonDaemons'}/logs/lonsql.pid";
-
- $restartflag=1;
-
- if (-e $lonsqlfile) {
- my $lfh=IO::File->new("$lonsqlfile");
- my $lonsqlpid=<$lfh>;
- chomp($lonsqlpid);
- if (kill 0 => $lonsqlpid) {
- print $fh "lonsql at pid $lonsqlpid responding
";
- $restartflag=0;
- } else {
- $errors++; $errors++;
- print $fh "lonsql at pid $lonsqlpid not responding
";
- $restartflag=1;
- print $fh
- "Decided to clean up stale .pid file and restart lonsql
";
- }
- }
- if ($restartflag==1) {
- $errors++;
- print $fh '
Killall lonsql: '.
- system('killall lonsql').' - ';
- sleep 2;
- print $fh unlink($lonsqlfile).' - '.
- system('killall -9 lonsql').
- '
';
- print $fh "lonsql not running, trying to start
";
- system(
- "$perlvar{'lonDaemons'}/lonsql 2>>$perlvar{'lonDaemons'}/logs/lonsql_errors");
- sleep 2;
- if (-e $lonsqlfile) {
- print $fh "Seems like it started ...lonsql at pid $lonsqlpid responding
";
+# --------------------------------------------------------------- clean out tmp
+ print $fh 'Temporary Files
';
+ $cleaned=0;
+ $old=0;
+ while ($fname=<$perlvar{'lonDaemons'}/tmp/*>) {
+ my ($dev,$ino,$mode,$nlink,
+ $uid,$gid,$rdev,$size,
+ $atime,$mtime,$ctime,
+ $blksize,$blocks)=stat($fname);
+ $now=time;
+ $since=$now-$mtime;
+ if ($since>$perlvar{'lonExpire'}) {
+ $line='';
+ if (open(PROBE,$fname)) {
+ $line=lonsql at pid $lonsqlpid not responding
";
- print $fh "Give it one more try ...";
- open (DFH,"tail -n100 $perlvar{'lonDaemons'}/logs/lonsql.log|");
- while ($line=
";
}
+
}
+ print $fh "Cleaned up ".$cleaned." files (".$old." old checkout tokens).";
- $fname="$perlvar{'lonDaemons'}/logs/lonsql.log";
-
- my ($dev,$ino,$mode,$nlink,
- $uid,$gid,$rdev,$size,
- $atime,$mtime,$ctime,
- $blksize,$blocks)=stat($fname);
+# ------------------------------------------------------------ clean out lonIDs
+ print $fh 'Session Tokens
';
+ $cleaned=0;
+ $active=0;
+ while ($fname=<$perlvar{'lonIDsDir'}/*>) {
+ my ($dev,$ino,$mode,$nlink,
+ $uid,$gid,$rdev,$size,
+ $atime,$mtime,$ctime,
+ $blksize,$blocks)=stat($fname);
+ $now=time;
+ $since=$now-$mtime;
+ if ($since>$perlvar{'lonExpire'}) {
+ $cleaned++;
+ print $fh "Unlinking $fname
";
+ unlink("$fname");
+ } else {
+ $active++;
+ }
- if ($size>200000) {
- print $fh "Rotating logs ...$active open session(s)
";
- &errout($fh);
-}
-# ------------------------------------------------------------------------ lond
-
-print $fh 'lond
Log
';
-print "lond\n";
+# ----------------------------------------------------------------------- httpd
-if (-e "$perlvar{'lonDaemons'}/logs/lond.log"){
-open (DFH,"tail -n25 $perlvar{'lonDaemons'}/logs/lond.log|");
-while ($line=
";
+ print $fh 'httpd
Access Log
';
+
+ open (DFH,"tail -n25 /etc/httpd/logs/access_log|");
+ while ($line=
Error Log
";
-$restartflag=1;
-if (-e $londfile) {
- my $lfh=IO::File->new("$londfile");
- my $londpid=<$lfh>;
- chomp($londpid);
- if (kill 0 => $londpid) {
- print $fh "
lond at pid $londpid responding, sending USR1
";
- kill USR1 => $londpid;
- $restartflag=0;
- } else {
- $errors++;
- print $fh "lond at pid $londpid not responding
";
- $restartflag=1;
- print $fh
- "Decided to clean up stale .pid file and restart lond
";
- }
-}
-if ($restartflag==1) {
- $errors++;
- print $fh '
Killall lond: '.
- system('killall lond').' - ';
- sleep 2;
- print $fh unlink($londfile).' - '.system('killall -9 lond').
- '
';
- print $fh "lond not running, trying to start
";
- system(
- "$perlvar{'lonDaemons'}/lond 2>>$perlvar{'lonDaemons'}/logs/lond_errors");
- sleep 2;
- if (-e $londfile) {
- print $fh "Seems like it started ...lond at pid $londpid responding
";
- } else {
- $errors++; $errors++;
- print $fh "lond at pid $londpid not responding
";
- print $fh "Give it one more try ...";
- open (DFH,"tail -n100 $perlvar{'lonDaemons'}/logs/lond.log|");
+ open (DFH,"tail -n25 /etc/httpd/logs/error_log|");
while ($line=
";
- }
-}
-
-$fname="$perlvar{'lonDaemons'}/logs/lond.log";
+ &errout($fh);
- my ($dev,$ino,$mode,$nlink,
- $uid,$gid,$rdev,$size,
- $atime,$mtime,$ctime,
- $blksize,$blocks)=stat($fname);
-
-if ($size>40000) {
- print $fh "Rotating logs ...lonc
Log
';
-print "lonc\n";
+ &checkon_daemon($fh,'lonsql',200000);
-if (-e "$perlvar{'lonDaemons'}/logs/lonc.log"){
-open (DFH,"tail -n25 $perlvar{'lonDaemons'}/logs/lonc.log|");
-while ($line=
";
-
-my $loncfile="$perlvar{'lonDaemons'}/logs/lonc.pid";
+# ------------------------------------------------------------------------ lond
-$restartflag=1;
-if (-e $loncfile) {
- my $lfh=IO::File->new("$loncfile");
- my $loncpid=<$lfh>;
- chomp($loncpid);
- if (kill 0 => $loncpid) {
- print $fh "lonc at pid $loncpid responding, sending USR1
";
- kill USR1 => $loncpid;
- $restartflag=0;
- } else {
- $errors++;
- print $fh "lonc at pid $loncpid not responding
";
- # Solution: kill parent and children processes, remove .pid and restart
- $restartflag=1;
- print $fh
- "Decided to clean up stale .pid file and restart lonc
";
- }
-}
-if ($restartflag==1) {
- $errors++;
- print $fh '
Killall lonc: '.
- system('killall lonc').' - ';
- sleep 2;
- print $fh unlink($loncfile).' - '.system('killall -9 lonc').
- '
';
- print $fh "lonc not running, trying to start
";
- system(
- "$perlvar{'lonDaemons'}/lonc 2>>$perlvar{'lonDaemons'}/logs/lonc_errors");
- sleep 2;
- if (-e $loncfile) {
- print $fh "Seems like it started ...lonc at pid $loncpid responding
";
- } else {
- $errors++; $errors++;
- print $fh "lonc at pid $loncpid not responding
";
- print $fh "Give it one more try ...";
- open (DFH,"tail -n100 $perlvar{'lonDaemons'}/logs/lonc.log|");
- while ($line=
";
- }
-}
+ &checkon_daemon($fh,'lond',40000,1);
-$fname="$perlvar{'lonDaemons'}/logs/lonc.log";
+# ------------------------------------------------------------------------ lonc
- my ($dev,$ino,$mode,$nlink,
- $uid,$gid,$rdev,$size,
- $atime,$mtime,$ctime,
- $blksize,$blocks)=stat($fname);
-
-if ($size>40000) {
- print $fh "Rotating logs ...lonhttpd
Log
';
-print "lonhttpd\n";
-
-if (-e "$perlvar{'lonDaemons'}/logs/lonhttpd.log"){
-open (DFH,"tail -n25 $perlvar{'lonDaemons'}/logs/lonhttpd.log|");
-while ($line=
";
-
-my $lonhttpdfile="$perlvar{'lonDaemons'}/logs/lonhttpd.pid";
+ &checkon_daemon($fh,'lonhttpd',40000);
-$restartflag=1;
-if (-e $lonhttpdfile) {
- my $lfh=IO::File->new("$lonhttpdfile");
- my $lonhttpdpid=<$lfh>;
- chomp($lonhttpdpid);
- if (kill 0 => $lonhttpdpid) {
- print $fh "lonhttpd at pid $lonhttpdpid responding
";
- $restartflag=0;
- } else {
- $errors++;
- print $fh "lonhttpd at pid $lonhttpdpid not responding
";
- # Solution: kill parent and children processes, remove .pid and restart
- $restartflag=1;
- print $fh
- "Decided to clean up stale .pid file and restart lonhttpd
";
- }
-}
-if ($restartflag==1) {
- $errors++;
- print $fh '
Killall lonhttpd: '.
- system('killall lonhttpd').' - ';
- sleep 2;
- print $fh unlink($lonhttpdfile).' - '.system('killall -9 lonhttpd').
- '
';
- print $fh "lonhttpd not running, trying to start
";
- system(
- "$perlvar{'lonDaemons'}/lonhttpd 2>>$perlvar{'lonDaemons'}/logs/lonhttpd_errors");
- sleep 2;
- if (-e $lonhttpdfile) {
- print $fh "Seems like it started ...lonhttpd at pid $lonhttpdpid responding
";
- } else {
- $errors++; $errors++;
- print $fh "lonhttpd at pid $lonhttpdpid not responding
";
- print $fh "Give it one more try ...";
- open (DFH,"tail -n100 $perlvar{'lonDaemons'}/logs/lonhttpd.log|");
- while ($line=
";
- }
-}
-
-$fname="$perlvar{'lonDaemons'}/logs/lonhttpd.log";
+# ---------------------------------------------------------------------- lonnet
- my ($dev,$ino,$mode,$nlink,
- $uid,$gid,$rdev,$size,
- $atime,$mtime,$ctime,
- $blksize,$blocks)=stat($fname);
-
-if ($size>40000) {
- print $fh "Rotating logs ...lonnet
Temp Log
';
+ print "checking logs\n";
+ if (-e "$perlvar{'lonDaemons'}/logs/lonnet.log"){
+ open (DFH,"tail -n50 $perlvar{'lonDaemons'}/logs/lonnet.log|");
+ while ($line=
Perm Log
";
+
+ if (-e "$perlvar{'lonDaemons'}/logs/lonnet.perm.log") {
+ open(DFH,"tail -n10 $perlvar{'lonDaemons'}/logs/lonnet.perm.log|");
+ while ($line=
";
+ &errout($fh);
# ----------------------------------------------------------------- Connections
-print $fh 'lonnet
Temp Log
';
-print "lonnet\n";
-if (-e "$perlvar{'lonDaemons'}/logs/lonnet.log"){
-open (DFH,"tail -n50 $perlvar{'lonDaemons'}/logs/lonnet.log|");
-while ($line=
Perm Log
";
+ my ($dev,$ino,$mode,$nlink,
+ $uid,$gid,$rdev,$size,
+ $atime,$mtime,$ctime,
+ $blksize,$blocks)=stat($fname);
-if (-e "$perlvar{'lonDaemons'}/logs/lonnet.perm.log") {
- open(DFH,"tail -n10 $perlvar{'lonDaemons'}/logs/lonnet.perm.log|");
-while ($line=
";
-&errout($fh);
+ print $fh "Connections
';
-
-print $fh "";
-foreach $tryserver (sort(keys(%hostname))) {
+ print $fh '
";
-&errout($fh);
+ &errout($fh);
# ------------------------------------------------------------ Delayed messages
-print $fh 'Connections
';
+ print "testing connections\n";
+ print $fh "";
+ foreach $tryserver (sort(keys(%hostname))) {
+ print(".");
+ $answer=reply("pong",$tryserver);
+ if ($answer eq "$tryserver:$perlvar{'lonHostID'}") {
+ $result="ok";
+ } else {
+ $result=$answer;
+ $warnings++;
+ if ($answer eq 'con_lost') { $warnings++; }
+ }
+ if ($answer =~ /con_lost/) { print(" $tryserver down\n"); }
+ print $fh "
";
+ print $fh " \n";
- $answer=reply("pong",$tryserver);
- if ($answer eq "$tryserver:$perlvar{'lonHostID'}") {
- $result="ok";
- } else {
- $result=$answer;
- $warnings++;
- if ($answer eq 'con_lost') { $warnings++; }
}
- print $fh "$tryserver $result \n";
-
-}
-print $fh "$tryserver $result Delayed Messages
';
-print "buffers\n";
+ print $fh 'Delayed Messages
';
+ print "checking buffers\n";
-print $fh 'Scanning Permanent Log
';
+ print $fh 'Scanning Permanent Log
';
-$unsend=0;
-{
- my $dfh=IO::File->new("$perlvar{'lonDaemons'}/logs/lonnet.perm.log");
- while ($line=<$dfh>) {
- ($time,$sdf,$dserv,$dcmd)=split(/:/,$line);
- if ($sdf eq 'F') {
- $local=localtime($time);
- print "Failed: $time, $dserv, $dcmd
";
- $warnings++;
- }
- if ($sdf eq 'S') { $unsend--; }
- if ($sdf eq 'D') { $unsend++; }
+ $unsend=0;
+ {
+ my $dfh=IO::File->new("$perlvar{'lonDaemons'}/logs/lonnet.perm.log");
+ while ($line=<$dfh>) {
+ ($time,$sdf,$dserv,$dcmd)=split(/:/,$line);
+ if ($sdf eq 'F') {
+ $local=localtime($time);
+ print $fh "Failed: $time, $dserv, $dcmd
";
+ $warnings++;
+ }
+ if ($sdf eq 'S') { $unsend--; }
+ if ($sdf eq 'D') { $unsend++; }
+ }
}
-}
-print $fh "Total unsend messages: $unsendOutgoing Buffer
";
+ if ($unsend) { $simplestatus{'unsend'}=$unsend; }
+ print $fh "Outgoing Buffer
";
-open (DFH,"ls -lF $perlvar{'lonSockDir'}/delayed|");
-while ($line=
";
-};
-close (DFH);
+ open (DFH,"ls -lF $perlvar{'lonSockDir'}/delayed|");
+ while ($line=
";
+ };
+ close (DFH);
# ------------------------------------------------------------------------- End
-print $fh "\n";
-$totalcount=$notices+4*$warnings+100*$errors;
-&errout($fh);
-print $fh "Total Error Count: $totalcount
";
-$now=time;
-$date=localtime($now);
-print $fh "
$date ($now)