1.编写代码
public class Demo {
public static void main(String[] args) {
System.err.println("测试开始");
while(true){
}
}
}
编写一个死循环代码。
执行此代码
2.找到CPU占用率高的进程
我们可以观察到top查看cpu占用高的进程。
找到cpu占用率为 100%的线程。
3. 导出执行堆栈
jstack 3417 >> java.txt
3417 为进程号
4. 查占用率高的线程
top -H -p 3417
找到线程号 为3418
5. 转换16进制
printf “%x\n” 3418
执行后 为 d5a
6. 在之前导出的堆栈文件查找
查找d5a
"main" #1 prio=5 os_prio=0 tid=0x00007f3ef804b000 nid=0xd5a runnable [0x00007f3efef94000]
java.lang.Thread.State: RUNNABLE
at Demo.main(Demo.java:4)
发现是我们的Demo第四行出了问题,这样找回源码,去掉死循环即可。
文档更新时间: 2022-02-14 10:09 作者:zyg