- top 查看各项使用情况(只能看到进程id)
- ps H -eo pid,tid,%cpu 命令查看 进程id 线程id cpu占用情况(找到线程占用过高的进程id)
- ps H -eo pid,tid,%cpu | grep xxx(进程id)筛选
ps H -eo pid,tid,%cpu | grep 32665 - jstack xxx(进程id) 查看进程的所有线程
打印的是每个线程的信息,将线程id(上面命令找到的tid 32665)由十进制转换为十六进制,找到nid=0x7f99(32665转换得0x7f99)的线程
上图提示:线程thread1 正在运行,且问题位置为 Demo1_16.java 的第8行,找到位置就可以解决问题了。
上图示例为死循环代码。 实际项目中可能是其他代码。
- 如果是gc问题 可以查看 传送门
- 如果是死锁导致结果一直不返回(死锁问题)
使用 jstack 进程id 命令查看
java linux cpu占用过高
最新推荐文章于 2023-07-20 09:39:43 发布