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

147 阅读1分钟

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

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

  1. 查找进程ID

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

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

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

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

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

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

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

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