JVM运维

找出某个线程出现死锁的原因

jstack [option] pid

第一步先找出Java进程ID

jps

第二步找出该进程内最耗费CPU的线程 top -Hp pid

(根据某个字段排序:先按f,进入字段选择选项,上下键选择,然后s确认,q退出,就实现了排序)

第3步 把耗时最久的线程Id用16进制表示

比如是772线程

第4步 jstack 输出

bash 复制代码
jstack 321 | grep 304

可以看到这里是条件等待 正常的等待

如果是异常的等待 可以进一步看jstack日志,看是哪一步的堆栈卡住的

相关推荐
shejizuopin2 分钟前
基于JavaSSM+MySQL的实验室考勤管理系统设计与实现
java·mysql·vue·毕业设计·论文·springboot·实验室考勤管理系统设计与实现
ZEERO~5 分钟前
@dataclass的作用
开发语言·windows·python
南行*12 分钟前
C语言Linux环境编程
linux·c语言·开发语言·网络安全
J***516813 分钟前
SpringSecurity的配置
java
Morwit14 分钟前
Qt qml创建c++类的单例对象
开发语言·c++·qt
面汤放盐15 分钟前
软件架构指南 Software Architecture Guide
java·微服务·devops
tkevinjd15 分钟前
JUC5(线程池)
java·线程池·多线程·juc
Tao____16 分钟前
如何对接Modbus-tcp协议(使用Thinlinks物联网平台)
java·物联网·网络协议·tcp/ip·modbus
古城小栈17 分钟前
Rust 已经自举,却仍需GNU与MSVC工具链的缘由
开发语言·rust
鱼跃鹰飞20 分钟前
经典面试题:K8S的自动缩扩容和崩溃恢复
java·容器·kubernetes