排查CPU占用高的代码
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第四行出了问题,这样找回源码,去掉死循环即可。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· winform 绘制太阳,地球,月球 运作规律
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· AI与.NET技术实操系列(五):向量存储与相似性搜索在 .NET 中的实现
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人