JAVA命令系列(四) : jstack
1、功能
jstack 是jvm自带的java线程堆栈跟踪工具,用于打印指定java进程的id、core file、远程调试服务的java堆栈信息
- jstack命令用于生成虚拟机当前时刻的线程快照。
- 线程出现停顿的时候通过jstack来查看各个线程的调用堆栈,就可以知道没有响应的线程到底在后台做什么事情,或者等待什么资源
- 如果java程序崩溃生成core文件,jstack工具可以用来获得core文件的java stack和native stack的信息,从而可以轻松地知道java程序是如何崩溃和在程序何处发生问题
2、位置
jstack 命令位于$JAVA_HOME/bin目录下
3、使用方法
option参数
- -F 当正常输出的请求不被响应时,强制输出线程堆栈
- -m mixed mode,不仅会输出Java堆栈信息,还会输出C/C++堆栈信息(比如Native方法)
- -l long listings,会打印出额外的锁信息,在发生死锁时可以用jstack -l pid来观察锁持有情况
使用jstack 导出java线程堆栈信息并输出到指定文件中
jstack -l pid > /opt/111.dump