--- loncom/init.d/loncontrol 2004/05/11 21:22:04 1.18 +++ loncom/init.d/loncontrol 2004/08/19 18:31:42 1.19 @@ -23,7 +23,7 @@ $ENV{'PATH'}="/sbin:/bin:/usr/sbin:/usr/ $ENV{'BASH_ENV'}=""; sub stop_daemon { - my ($daemon)=@_; + my ($daemon,$killallname)=@_; my $pidfile="/home/httpd/perl/logs/$daemon.pid"; printf("%-10s ",$daemon); @@ -37,22 +37,29 @@ sub stop_daemon { kill KILL => $daemonpid; sleep 2; if (kill 0 => $daemonpid) { - print("failed to kill\n"); return; + print("failed to kill"); } else { - print("killed\n"); return; + print("killed"); } } else { - print("stopped\n"); return; + print("stopped"); } + } else { + print("not running"); } - print("not running\n"); + system("killall -q -0 $killallname"); + if ($? == 0) { + system("killall -q $killallname"); + print(", killed off extraneous processes"); + } + print("\n"); } if (($command eq "restartold") or ($command eq "reloadold")) { print 'Restarting LON-CAPA'."\n"; print 'Ending LON-CAPA client and daemon processes'."\n"; foreach my $daemon ('lonsql','lond','lonc','lonhttpd') { - &stop_daemon($daemon); + &stop_daemon($daemon,$daemon); } print 'Starting LON-CAPA client and daemon processes (please be patient)'. "\n"; @@ -61,7 +68,9 @@ if (($command eq "restartold") or ($comm print 'Restarting LON-CAPA'."\n"; print 'Ending LON-CAPA client and daemon processes'."\n"; foreach my $daemon ('lonsql','lond','lonc','lonhttpd') { - &stop_daemon($daemon); + my $killallname=$daemon; + if ($daemon eq 'lonc') { $killallname='loncnew'; } + &stop_daemon($daemon,$killallname); } print 'Starting LON-CAPA client and daemon processes (please be patient)'. "\n"; @@ -69,7 +78,9 @@ if (($command eq "restartold") or ($comm } elsif ($command eq "stop") { print 'Stopping LON-CAPA'."\n"; foreach my $daemon ('lonsql','lond','lonc','lonhttpd') { - &stop_daemon($daemon); + my $killallname=$daemon; + if ($daemon eq 'lonc') { $killallname='loncnew'; } + &stop_daemon($daemon,$killallname); } } elsif ($command eq "startold") { print 'Starting LON-CAPA'."\n";