mirror of
				https://github.com/asterisk/asterisk.git
				synced 2025-10-31 10:47:18 +00:00 
			
		
		
		
	add script for grabbing core dump from running Asterisk process (bug #4174)
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@5671 65c4cc65-6c06-0410-ace0-fbb531ad65f3
This commit is contained in:
		
							
								
								
									
										64
									
								
								contrib/scripts/ast_grab_core
									
									
									
									
									
										Executable file
									
								
							
							
						
						
									
										64
									
								
								contrib/scripts/ast_grab_core
									
									
									
									
									
										Executable 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! | ||||
		Reference in New Issue
	
	Block a user