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 @   huyang0726  阅读(1255)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· DeepSeek 开源周回顾「GitHub 热点速览」
· 记一次.NET内存居高不下排查解决与启示
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· .NET10 - 预览版1新功能体验(一)
点击右上角即可分享
微信分享提示