--- loncom/init.d/loncontrol 2003/02/03 18:03:52 1.10 +++ loncom/init.d/loncontrol 2003/09/16 21:01:39 1.11 @@ -22,17 +22,47 @@ $command=$ARGV[0]; $command=~s/[^a-z]//g $ENV{'PATH'}="/sbin:/bin:/usr/sbin:/usr/bin:/usr/X11R6/bin:/root/bin"; $ENV{'BASH_ENV'}=""; +sub stop_daemon { + my ($daemon)=@_; + my $pidfile="/home/httpd/perl/logs/$daemon.pid"; + + printf("%-10s ",$daemon); + if (-e $pidfile) { + open(PIDFILE,$pidfile); + my $daemonpid=; + chomp($daemonpid); + kill TERM => $daemonpid; + sleep 2; + if (kill 0 => $daemonpid) { + kill KILL => $daemonpid; + sleep 2; + if (kill 0 => $daemonpid) { + print("failed to kill\n"); return; + } else { + print("killed\n"); return; + } + } else { + print("stopped\n"); return; + } + } + print("not running\n"); +} + if (($command eq "restart") or ($command eq "reload")) { print 'Restarting LON-CAPA'."\n"; print 'Ending LON-CAPA client and daemon processes'."\n"; - print `su -c '/bin/kill \`/bin/cat /home/httpd/perl/logs/*.pid\`' www`; + foreach my $daemon ('lonsql','lond','lonc','lonhttpd') { + &stop_daemon($daemon); + } print 'Starting LON-CAPA client and daemon processes (please be patient)'. "\n"; system("su -c '/home/httpd/perl/loncron' www"); } elsif ($command eq "stop") { print 'Stopping LON-CAPA'."\n"; - print `su -c '/bin/kill \`/bin/cat /home/httpd/perl/logs/*.pid\`' www`; + foreach my $daemon ('lonsql','lond','lonc','lonhttpd') { + &stop_daemon($daemon); + } } elsif ($command eq "start") { print 'Starting LON-CAPA'."\n";