一次CPU负载过高的问题排查

问题现象:

最近几天线上总是间歇性的报警——cpu使用率过高,而且cpu使用率都是整点飙升的。

 

排查方法一

步骤一:查询当前占用cpu最高的进程

top命令

经过几秒钟的观察,发现java进程耗用cpu过多,对应的进程id:64567

步骤二:查询进程id:64567内,耗费cpu最多的线程

top -p 进程id -H

-p :指定某些个 PID 来进行观察监测而已。

-H :线程模式

如图,占用cpu最大的线程对应的线程id是:92668

步骤三:将线程id转为十六进制

printf ‘%x \n'  92668

 

步骤四:找到对应线程的堆栈

jstack 进程id | grep 线程id(十六进制) -C 50

方法一的缺点:如果一个机器的cpu使用率飙升,通过上面方式排查比较麻烦,对于步骤二如果top之后发现有多个线程的cpu占有率比较高,并且cpu只是短暂的飙升,那么这个方法耗时比较久。可能找到所有的线程之后打出堆栈,cpu使用率飙升现场已经没有了。所以才给出了方法二进行排查,方法比较简单。

排查方法二

安装arthas:curl -L http://start.alibaba-inc.com/install.sh | sh

通过使用arthas对应的命令thread -n 找到cpu使用率top n的线程,并且打印出堆栈。通过arthas,我们可以使用一个命令就完成上面四个步骤的工作,比较简单方便

 

结论

通过排查发现导致cpu利用率飙升的原因,主要有两点处理耗cpu:1、稽核任务对近一年的合同(抽取的合同)频繁的查询数据库里面的promotion、property、contract_vip_record表做查询;2、对数据库做操作的异步日志记录;

 

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
Linux排查CPU负载过高的原因通常有以下几个方面: 1. 进程负载过高:可以通过使用top命令或htop命令查看当前系统的进程状态,找到最耗CPU进程,并检查其是否正常运行。如果是某个进程导致的负载过高,可以进一步使用ps命令查看该进程的详细信息,并根据需要采取相应的措施,如重新启动进程或优化进程配置。 2. 线程负载过高:如果是线程导致的负载过高,可以使用工具如top、htop或pidstat等来找到最耗CPU的线程,并将线程PID转化为16进制。然后根据线程的PID进一步分析线程的运行状态和资源消耗情况,进行排查和调优。 3. 内存泄漏和频繁GC:内存泄漏和频繁的垃圾回收(GC)也可能导致CPU负载过高。可以通过使用jstat命令或Java监控工具(如VisualVM)来检查Java应用的内存使用情况,并查看是否存在内存泄漏或GC频繁的问题。如果存在问题,可以通过调整JVM启动参数或优化代码来解决。 4. 其他系统资源问题:除了CPU负载过高外,还可能存在其他系统资源的问题,如内存被耗尽、磁盘IO或网络出现问题等。可以使用命令如free、df、iostat和netstat等来检查系统的内存、磁盘IO和网络等情况,以确定是否存在相关问题。 相关问题: 1. 如何使用top命令查看系统进程状态? 2. 如何使用ps命令查看进程详细信息? 3. 如何使用jstat命令检查Java应用的内存使用情况?

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

云夢南行

你的打赏是我创作的动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值