diff options
author | matteo <matteo@f38db490-d61c-443f-a65b-d21fe96a405b> | 2003-02-18 18:15:30 +0000 |
---|---|---|
committer | matteo <matteo@f38db490-d61c-443f-a65b-d21fe96a405b> | 2003-02-18 18:15:30 +0000 |
commit | 28be2d6a7cb7f8915b0f346a9a2c02dd2fc5bf1f (patch) | |
tree | 0de34ae75587bde85880b54639d681ab4e4b986a /contrib/scripts | |
parent | 08261a60e010fae1f1ecb545a98fccbde00b59b6 (diff) |
mar feb 18 19:15:15 CET 2003
git-svn-id: http://svn.digium.com/svn/asterisk/trunk@618 f38db490-d61c-443f-a65b-d21fe96a405b
Diffstat (limited to 'contrib/scripts')
-rwxr-xr-x | contrib/scripts/safe_asterisk | 29 |
1 files changed, 25 insertions, 4 deletions
diff --git a/contrib/scripts/safe_asterisk b/contrib/scripts/safe_asterisk index ad4ba124e..9180e838b 100755 --- a/contrib/scripts/safe_asterisk +++ b/contrib/scripts/safe_asterisk @@ -1,17 +1,30 @@ #!/bin/sh TTY=9 # TTY (if you want one) for Asterisk to run on CONSOLE=yes # Whether or not you want a console -NOTIFY= # Who to notify about crashes +#NOTIFY=ben@alkaloid.net # Who to notify about crashes +DUMPDROP=/tmp # # Don't fork when running "safely" # ASTARGS="" if [ "$TTY" != "" ]; then + if [ -c /dev/tty${TTY} ]; then + TTY=tty${TTY} + elif [ -c /dev/vc/${TTY} ]; then + TTY=vc/${TTY} + else + echo "Cannot find your TTY (${TTY})" >&2 + exit 1 + fi ASTARGS="${ASTARGS} -vvv" if [ "$CONSOLE" != "no" ]; then ASTARGS="${ASTARGS} -c" fi fi +if [ ! -w ${DUMPDROP} ]; then + echo "Cannot write to ${DUMPDROP}" >&2 + exit 1 +fi # # Let Asterisk dump core @@ -27,13 +40,15 @@ run_asterisk() while :; do if [ "$TTY" != "" ]; then - stty sane < /dev/tty${TTY} - asterisk ${ASTARGS} >& /dev/tty${TTY} < /dev/tty${TTY} + cd /tmp + stty sane < /dev/${TTY} + asterisk ${ASTARGS} >& /dev/${TTY} < /dev/${TTY} else + cd /tmp asterisk ${ASTARGS} fi EXITSTATUS=$? - #echo "Asterisk ended with exit status $EXITSTATUS" + echo "Asterisk ended with exit status $EXITSTATUS" if [ "$EXITSTATUS" = "0" ]; then # Properly shutdown.... echo "Asterisk shutdown normally." @@ -45,8 +60,14 @@ run_asterisk() echo "Asterisk exited on signal $EXITSIGNAL. Might want to take a peek." | \ mail -s "Asterisk Died" $NOTIFY fi + if [ -f /tmp/core ]; then + mv /tmp/core ${DUMPDROP}/core.`hostname`-`date -Iseconds` & + fi else echo "Asterisk died with code $EXITSTATUS. Aborting." + if [ -f /tmp/core ]; then + mv /tmp/core ${DUMPDROP}/core.`hostname`-`date -Iseconds` & + fi exit 0 fi echo "Automatically restarting Asterisk." |