分析占用了大量 CPU 处理时间的是Java 进程中哪个线程

下面是详细步骤:


1. 首先确定进程的 ID ,可以使用 jps -v 或者 top 命令直接查看


2. 查看该进程中哪个线程占用大量 CPU,执行 top -H -p [PID] 结果如下:


cpu100.jpeg

可以发现编号为 350xx 的共有 9 个线程占用了 100% 的 CPU,好,接下来咱们随便取一个线程 ID ,假设我们想看编号为 35053 这个线程。


首先将 35053 转成 16 进制是 88ED (可以用开源中国在线工具转换)


3. 接下来我们将进程中的所有线程输出到一个文件中,执行:jstack [PID] > jstack.txt


4. 在进程中查找对应的线程 ID,执行:cat jstack.txt | grep -i 88ED


结果是:


"HTTP Request From : /xxxx/blog/323432(120.27.143.239)" #266 daemon prio=5 os_prio=0 tid=0x00007fcda4146800 nid=0x88e runnable [0x00007fcd54178000]

由此可以看出在请求 /xxxx/blog/323432 链接的时候,服务器的处理线程占用了 100% 的 CPU。



原文地址:分析占用了大量 CPU 处理时间的是Java 进程中哪个线程
标签:java   cup100%   线程   

智能推荐

posted on   即学即码+  阅读(941)  评论(0编辑  收藏  举报

编辑推荐:
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
阅读排行:
· 25岁的心里话
· 闲置电脑爆改个人服务器(超详细) #公网映射 #Vmware虚拟网络编辑器
· 零经验选手,Compose 一天开发一款小游戏!
· 通过 API 将Deepseek响应流式内容输出到前端
· AI Agent开发,如何调用三方的API Function,是通过提示词来发起调用的吗
< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

统计

点击右上角即可分享
微信分享提示