博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
如何找到 Java 进程中哪个线程占用了大量 CPU 处理时间
阅读量:6926 次
发布时间:2019-06-27

本文共 656 字,大约阅读时间需要 2 分钟。

hot3.png

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

下面是详细步骤:

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

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

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

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

转载于:https://my.oschina.net/javayou/blog/1627245

你可能感兴趣的文章
【玩转开源】使用 PhoenixSuit 线刷 Android 镜像
查看>>
PHP json_decode返回null解析失败原因
查看>>
如何使用putty登录群晖ds218play的linux系统
查看>>
更新本地代码到服务器的shell脚本
查看>>
园区无线网络的搭建流程
查看>>
南京邮电大学java第二次实验报告
查看>>
算法学习一
查看>>
【ZZ】Linux常用指令
查看>>
函数:module_put ( )【转】
查看>>
Fragment生命周期及在viewpager中的生命周期
查看>>
Android触控(一) 关于MotionEvent的学习
查看>>
java 并发生成商品编号
查看>>
AngularJS Http
查看>>
实验四 主存空间的分配和回收模拟
查看>>
配置puppet的主机端和客户端的自动认证
查看>>
经典排序算法 - 冒泡排序Bubble sort
查看>>
网站返回301、302、200、206等系列代码HTTP状态介绍
查看>>
vue后台管理项目中菜单栏切换的三种方法
查看>>
jquery框架概览(二)
查看>>
Struts2自定义初始化及Properties文件操作
查看>>