dect
/
asterisk
Archived
13
0
Fork 0

add script for grabbing core dump from running Asterisk process (bug #4174)

git-svn-id: http://svn.digium.com/svn/asterisk/trunk@5671 f38db490-d61c-443f-a65b-d21fe96a405b
This commit is contained in:
kpfleming 2005-05-15 05:07:14 +00:00
parent c8c9acf505
commit 9bc8a6439f
1 changed files with 64 additions and 0 deletions

64
contrib/scripts/ast_grab_core Executable file
View File

@ -0,0 +1,64 @@
#!/bin/sh
# $Id$
# lame quickie script to snarf a core of a hung asterisk process.
# bugs to ast_grab_core, blinky-lights.org (derrick daugherty)
DATE=`date +%Y%m%d%H%M`
DUMPDIR=/var/tmp
HOSTNAME=`hostname`
ADMINEMAIL="root@localhost"
#the following should be improved
if [ -e /etc/asterisk/asterisk.conf ]; then
RUNDIR=`awk -F"=>" '/astrundir/ {print $2}' /etc/asterisk/asterisk.conf`
PID=`cat ${RUNDIR}/asterisk.pid`
elif [ -e /var/run/asterisk.pid ] ; then
PID=`cat /var/run/asterisk.pid`
else
echo Could not find an asterisk.conf definition for astrundir, using \'ps\'
echo to try and determine process ID. This is not reliable.
PID=`ps auxwf|grep asterisk|grep vv|head -1|awk '{print $2}'`
fi
echo Snarfing asterisk core, this could take a few seconds depending
echo on how much memory is in use.
echo
echo \*\*\* WARNING \*\*\* If the system is not already locked this will cause the
echo \*\*\* WARNING \*\*\* process to STOP while memory is dumped to disk.
echo
/usr/bin/gdb > /dev/null << EOF
attach ${PID}
gcore ${DUMPDIR}/asterisk_${DATE}.core.${PID}
detach
quit
EOF
echo Snarfed! ${DUMPDIR}/asterisk_${DATE}.core.${PID}
echo
echo Trying for a backtrace of the captured core.
/usr/bin/gdb /usr/sbin/asterisk ${DUMPDIR}/asterisk_${DATE}.core.${PID} > /tmp/gdb_dump.${PID} 2> /dev/null << EOF
set prompt \n
echo --------------------------------------------------------------------------------\n
echo INFO THREAD
info thread
echo --------------------------------------------------------------------------------\n
echo THREAD APPLY ALL BT
thread apply all bt
echo --------------------------------------------------------------------------------\n
echo THREAD APPLY ALL BT FULL
thread apply all bt full
quit
EOF
echo Done trying for a bt.
echo Notifying admins of the core.
/usr/bin/mail -s "${HOSTNAME} core dumped at ${DUMPDIR}/asterisk_${DATE}.core.${PID}" ${ADMINEMAIL} < /tmp/gdb_dump.${PID}
/bin/rm /tmp/gdb_dump.${PID}
echo Done.
echo
echo Reproducible deadlocks should be posted with a full backtrace and instructions
echo to reproduce the issue at http://bugs.digium.com/ Thanks!