jvm-监控指令-jstack
格式:
jstack [option] vmid
选项:
-l 除了堆栈信息外,显示关于锁的附加信息。
作用:
生成虚拟机当前时刻的线程快照。
目的:
定位线程长时间停顿的原因,比如线程间死锁、死循环、请求外部资源导致的长时间等待。
使用步骤:
1
. 获取进程id。 常用命令:
ps -aux | grep java
jps -lv
top
2
. 得到线程快照。
jstack -l 进程id > 文件
1
3
. 根据进程id,得到线程的资源使用情况。
top -H -p 进程id > 文件
2
4
. 将耗时的线程id,转化为
16
进制数的表示形式。
5
. 根据
16
进制的线程id,在线程快照中查找。
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】博客园社区专享云产品让利特惠,阿里云新客6.5折上折
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 没有源码,如何修改代码逻辑?
· 一个奇形怪状的面试题:Bean中的CHM要不要加volatile?
· [.NET]调用本地 Deepseek 模型
· 一个费力不讨好的项目,让我损失了近一半的绩效!
· 没有源码,如何修改代码逻辑?
· PowerShell开发游戏 · 打蜜蜂
· 在鹅厂做java开发是什么体验
· 百万级群聊的设计实践
· WPF到Web的无缝过渡:英雄联盟客户端的OpenSilver迁移实战