排查Java高CPU占用原因

简介: 开篇 在简书看到一篇公众号讲如何排查CPU问题,想了想在日常工作中也偶尔遇到这样的问题,所以在网上搜了搜该方面的文章,特意拷贝了一篇文章作日后排查参考。

开篇

 在简书看到一篇公众号讲如何排查CPU问题,想了想在日常工作中也偶尔遇到这样的问题,所以在网上搜了搜该方面的文章,特意拷贝了一篇文章作日后排查参考。

 整体来说是按照三步走:

  • 1、top命令发现占用cpu最多的进程PID
  • 2、ps命令查看该进程下占用cpu最多的线程tid并转换为16进制;
  • 3、jstack -l pid 保存进程堆栈并通过16进制的tid查找对应的代码块。


步骤

  • 1、top命令发现某个进程占用了100%的CPU
img_53af1437eb4c8de75ef01830cc1101be.png


  • 2、通过ps命令,进一步确定哪个进程出了问题
img_bb26d04efb60b2876d50eafaaecbea1d.png


  • 3、再查看线程占用CPU的列表
ps -mp PID(进程号)  -o THREAD,tid,time

说明:
-m Show threads after processes
img_ca7c8d956438265aed3f310223663acd.png


  • 4、找到占用CPU最高的线程,查看TID,将其转换为16进制格式
printf "%x\n" TID


  • 5、而后查看堆栈信息
jstack PID |grep 16进制TID -A 60
img_63a52188bb87ceb6bb49f92483af60a3.png


参考

目录
相关文章
|
2月前
|
运维 监控 网络协议
JAVA 线上故障排查完整套路,从 CPU、磁盘、内存、网络、GC
JAVA 线上故障排查完整套路,从 CPU、磁盘、内存、网络、GC
66 0
|
2月前
|
Java Linux
java查看CPU使用过高(linux)
java查看CPU使用过高(linux)
24 0
|
2月前
|
缓存 算法 安全
【JVM故障问题排查心得】「Java技术体系方向」Java虚拟机内存优化之虚拟机参数调优原理介绍(二)
【JVM故障问题排查心得】「Java技术体系方向」Java虚拟机内存优化之虚拟机参数调优原理介绍
18 0
|
2月前
|
缓存 Java C#
【JVM故障问题排查心得】「Java技术体系方向」Java虚拟机内存优化之虚拟机参数调优原理介绍(一)
【JVM故障问题排查心得】「Java技术体系方向」Java虚拟机内存优化之虚拟机参数调优原理介绍
86 0
|
7天前
|
搜索推荐 Linux 网络安全
记一次CPU 100%的问题排查过程
记一次CPU 100%的问题排查过程
15 0
|
1月前
|
监控 Java
Java项目jar性能监控工具CPU内存等
Java项目jar性能监控工具CPU内存等
12 0
|
1月前
|
Java Shell
java中jvm使用jststak定位线程cpu占用内存高的线程
java中jvm使用jststak定位线程cpu占用内存高的线程
11 5
|
2月前
|
SQL 运维 NoSQL
【Redis 故障排查】「连接失败问题排查和解决」带你总体分析CPU及内存的使用率高问题排查指南及方案
【Redis 故障排查】「连接失败问题排查和解决」带你总体分析CPU及内存的使用率高问题排查指南及方案
38 0
|
2月前
|
监控 网络协议 NoSQL
java线上排查OOM内存溢出
java线上排查OOM内存溢出
33 1
|
8天前
|
Linux
Linux rsyslog占用内存CPU过高解决办法
该文档描述了`rsyslog`占用内存过高的问题及其解决方案。
30 4