CPU占用过高排查

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提供的命令。可以查看某个进程的当前线程栈运行情况。根据这个命令的输出可以定位某个进程的所有线程的当前运行状态、运行代码,以及是否死锁等等。

4、pstack:Linux命令。可以查看某个进程的当前线程栈运行情况。

  • 0
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值