如何生成堆栈的Dump?
有下面3种方法,可以得到Java系统的堆栈信息。
1、给JVM发生信号
UNIX/Linux: kill -3 <pid>
Windows: Ctrl + Break
2、JVM运行时,内部错误引发显示堆栈信息
3、使用debug工具或者Java程序调用
在Java debuger中输入命令where,或用如下方法可以得到部分的堆栈信息:
Thread.dumpStack()
Throwable.printStackTrace()
得到堆栈信息后,第一件事情就是找出当前的执行线程、找出Runnable的线程、检查monitors。
通常,如果系统停滞了,需要检查堆栈信息确认是否死锁了。
一个很忙的系统,跟踪堆栈信息时,最好能多次生成堆栈信息,这样才能容易跟踪各种分支情况。