linux下查询java项目中哪个线程方法占用高内存cpu

举报
知识浅谈 发表于 2022/06/30 16:58:02 2022/06/30
【摘要】 linux下查询java项目中哪个线程方法占用高内存cpu

linux下查询java项目中哪个线程方法占用高内存cpu

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

  1. 查找进程ID

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

  1. 查找指定进程的占用高cpu的线程ID

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

就拿3609这个线程举例,因为都基本不占什么cpu,好,接下来咱们随便取一个线程 ID ,假设我们想看编号为 3609 这个线程。

首先将 3609 转成 16 进制是 E19 (可以用在线工具转换)

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

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

  3. 找到对应的线程对应的程序位置,进行相应修改即可。

【版权声明】本文为华为云社区用户原创内容,转载时必须标注文章的来源(华为云社区)、文章链接、文章作者等基本信息, 否则作者和本社区有权追究责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。