随笔 - 441  文章 - 4  评论 - 84  阅读 - 109万 

 排查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第四行出了问题,这样找回源码,去掉死循环即可。

 

posted on   自由港  阅读(59)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· winform 绘制太阳,地球,月球 运作规律
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· AI与.NET技术实操系列(五):向量存储与相似性搜索在 .NET 中的实现
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
点击右上角即可分享
微信分享提示