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

 

posted @ 2022-02-27 22:22  huyang0726  阅读(1163)  评论(0编辑  收藏  举报