diff options
author | Evan Prodromou <evan@controlyourself.ca> | 2009-03-08 11:52:45 -0700 |
---|---|---|
committer | Evan Prodromou <evan@controlyourself.ca> | 2009-03-08 11:52:45 -0700 |
commit | 6101280cd93ca77eb322160c9d0ccaf0ff319b07 (patch) | |
tree | b0b811b3d3671aeb53eb1f83a3d76e55e5e73bd8 | |
parent | c97142ad3edea1652f39e7fb58c8c3443f8a0f67 (diff) | |
parent | 1df3eeba861f9f5b7be7fd1ad4298f614a6cbee5 (diff) |
Merge branch '0.7.x' of git@gitorious.org:laconica/dev into 0.7.x
-rwxr-xr-x | scripts/stopdaemons.sh | 29 |
1 files changed, 20 insertions, 9 deletions
diff --git a/scripts/stopdaemons.sh b/scripts/stopdaemons.sh index fd4406d41..2bb8f9ecb 100755 --- a/scripts/stopdaemons.sh +++ b/scripts/stopdaemons.sh @@ -1,4 +1,4 @@ -#!/bin/sh +#!/bin/bash # Laconica - a distributed open-source microblogging tool @@ -23,19 +23,30 @@ SDIR=`dirname $0` DIR=`php $SDIR/getpiddir.php` -for f in jabberhandler ombhandler publichandler smshandler \ +for f in jabberhandler ombhandler publichandler smshandler pinghandler \ xmppconfirmhandler xmppdaemon twitterhandler facebookhandler ; do FILES="$DIR/$f.*.pid" for ff in "$FILES" ; do - echo -n "Stopping $f..." - PID=`cat $ff` - kill -3 $PID - if kill -9 $PID ; then - echo "DONE." - else - echo "FAILED." + PID=`cat $ff 2>/dev/null` + if [ -n "$PID" ] ; then + echo -n "Stopping $f ($PID)..." + if kill -3 $PID 2>/dev/null ; then + count=0 + while kill -0 $PID 2>/dev/null ; do + sleep 1 + count=$(($count + 1)) + if [ $count -gt 5 ]; then break; fi + done + if kill -9 $PID 2>/dev/null ; then + echo "FORCIBLY TERMINATED" + else + echo "STOPPED CLEANLY" + fi + else + echo "NOT FOUND" + fi fi rm -f $ff done |