CPU占用过高排查步骤 1、top命令查看应用占用CPU情况:top
2、确定是否是 tomcat 的 java 进程 :ps aux|grep pid
3、显示该进程的线程列表,确定那个线程占用CPU过高:ps -mp pid -o THREAD,tid,time
4. 将线程 tid 进行16进制转换:printf "%x\n" tid
5、显示堆栈信息,定位问题代码:jstack pid | grep tid -A 30
一个应用占用CPU很高,除了确实是计算密集型应用之外,通常原因都是出现了死循环。下面用示例给大家分别介绍一下:
一、top命令执行,如下图:
文章图片
根据top命令,发现 pid为 28555 的 java进程占用CPU高达200%,出现问题
二、ps aux | grep pid命令
可以进一步确定是tomcat的java进程出现了问题
三、 显示进程的线程列表
ps -mp pid -o THREAD,tid,time , 如下图
文章图片
从上图可知:耗时最高和最长时间的线程tid是 28802,占用CPU 60% 和 将近2个小时
四、将线程ID转换为16进制格式
执行 printf "%x\n" tid 命令,如下图:
文章图片
五、显示堆栈信息,定位问题代码
注意:这里的tid是转换16进制后的线程id
jstack pid |grep tid -A 30
文章图片
根据上图定位到了问题代码106行
最后,总结下排查CPU故障的方法和技巧有哪些:
1、top命令:Linux命令。可以查看实时的CPU使用情况。也可以查看最近一段时间的CPU使用情况。
2、ps命令: Linux命令。强大的进程状态监控命令。可以查看进程以及进程中线程的当前CPU使用情况。属于当前状态的采样数据。
3、jstack:Java提供的命令。可以查看某个进程的当前线程栈运行情况。根据这个命令的输出可以定位某个进程的所有线程的当前运行状态、运行代码,以及是否死锁等等。
【CPU占用过高排查】4、pstack:Linux命令。可以查看某个进程的当前线程栈运行情况。
推荐阅读
- jvm|【JVM】JVM08(java内存模型解析[JMM])
- jvm|JVM调优(线上 JVM GC 频繁耗时长,出现 LongGC 告警,这次排查后想说:还有谁(...))
- java内存区域与内存溢出异常
- JVM|JVM优化(一)
- 自动内存管理机制
- JVM: 使用 jstack 命令找出 cpu 飙高的原因
- java|JVM之字节码如何在jvm流转
- jvm|从栈帧看字节码是如何在 JVM 中进行流转的
- java|[NIO和Netty] NIO和Netty系列(二): Java Reference详解
- 生活|jrebeleclipse/tomcat 使用方法