Linux下有时候我们需要知道一个进程在做什么,比如说程序不正常的时候,他到底在干吗?最直接的方法就是打印出他所有线程的调用栈,这样我们从栈再配合程序代码就知道程序在干吗了。
Linux下这个工具叫做pstack. 使用方法是
Usage: pstack <process- id > |
当然这个被调查的程序需要有符号信息。 比较雷人的是 这个程序竟然是个shell脚本,核心实现是gdb的
thread apply all bt, 我们可以观摩下他的实现,这个我们做类似的程序提供了一个很好的思路:
echo
"Usage: `basename $0 .sh` <process-id>"
1>&2 |
if test
! -r /proc/$1; then |
echo
"Process $1 not found." 1>&2 |
if test
-d /proc/$1/task ; then |
if
test `/bin/ ls
/proc/$1/task | /usr/bin/ wc
-l` - gt
1 2>/dev/null ; then |
backtrace= "thread apply all bt" |
elif test
-f /proc/$1/maps ; then |
if
/bin/ grep
-e libpthread /proc/$1/maps > /dev/null 2>&1 ; then |
backtrace= "thread apply all bt" |
if $GDB -nx --quiet --batch --readnever > /dev/null 2>&1;
then |
$GDB --quiet $readnever -nx /proc/$1/exe $1 <<EOF 2>&1 | |
祝大家玩的开心。