#java线程问题排查
jstack: command not found 的错误时,说明 jstack 命令未被找到。这通常是因为 jstack 不在系统的 PATH 环境变量中,或者 JDK 未正确安装或配置。
- 确认 JDK 安装
检查 JDK 是否已安装并正确配置。
命令:
下面展示一些内联代码片
。
java -version
- 查找 jstack 可执行文件
查找 jstack 可执行文件的位置。
命令:
which jstack
如果找不到,可以通过 JDK 的安装路径手动查找。
命令:
find /usr/lib/jvm -name jstack
- 添加 jstack 到 PATH
将 jstack 的路径添加到 PATH 环境变量中。
编辑 .bashrc 文件:
nano ~/.bashrc
保存并退出编辑器。
使更改生效:
source ~/.bashrc
验证是否生效
- 使用 sudo 生成线程 Dump
现在可以使用 sudo 生成线程 Dump 文件。
命令:
sudo jstack <pid> > thread_dump.txt
分析线程 Dump 文件
一旦生成了线程 Dump 文件,可以使用以下命令查看内容:
命令:
cat thread_dump.txt
分析步骤
查找阻塞的线程:
查看哪些线程处于 WAITING 或 BLOCKED 状态。
在上面的例子中,Thread-1 和 Thread-2 都处于等待状态。
查找锁竞争:
查看哪些线程持有锁,哪些线程等待锁。
在上面的例子中,Thread-2 被阻塞在 ReentrantLock 上。