阿里云-云小站(无限量代金券发放中)
【腾讯云】云服务器、云数据库、COS、CDN、短信等热卖云产品特惠抢购

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

35次阅读
没有评论

共计 666 个字符,预计需要花费 2 分钟才能阅读完成。

摘要 本文的目的是在 Java 进程中确定哪个线程正在占用 CPU 的时间。当您的系统 CPU 负载居高不下时,这是一种有用的故障排除技术。
本文的目的是在 Java 进程中确定哪个线程正在占用 CPU 的时间。当您的系统 CPU 负载居高不下时,这是一种有用的故障排除技术。
下面是详细步骤:

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

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

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

可以发现编号为 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。

找到问题后,接下来去解决就好了!

阿里云 2 核 2G 服务器 3M 带宽 61 元 1 年,有高配

腾讯云新客低至 82 元 / 年,老客户 99 元 / 年

代金券:在阿里云专用满减优惠券

正文完
星哥说事-微信公众号
post-qrcode
 0
星锅
版权声明:本站原创文章,由 星锅 于2024-07-24发表,共计666字。
转载说明:除特殊说明外本站文章皆由CC-4.0协议发布,转载请注明出处。
【腾讯云】推广者专属福利,新客户无门槛领取总价值高达2860元代金券,每种代金券限量500张,先到先得。
阿里云-最新活动爆款每日限量供应
评论(没有评论)
验证码
【腾讯云】云服务器、云数据库、COS、CDN、短信等云产品特惠热卖中