线上故障排查之线上系统CPU负载过高排查

通常这个需要结合Linux命令和LDK的工具一起使用来排查。

1.先用top命令找出CPU占比最高的程序

2.使用ps -ef或者jps进一步定位,得知是一个怎么样的一个后台程序造成CPU负载过高

3.定位到具体线程或者代码

   3.1 ps -mp 进程号 -o THREAD,tid,time

上图中定位到线程5102cpu占用率较高。因此知道线程id为5102

命令参数解析:

  • -m 显示所有的线程
  • -p pid进程使用CPU的时间
  • -o 该参数后是用户自定义格式

4.将需要的线程ID转换为16进制格式(英文小写格式)

用以下命令转换:

printf "%x\n" 线程ID

5102转后为  13ee 

不会的话,可以用计算器去转换。

5.jstack 进程ID | grep tid(16进制线程ID小写英文) -A60

这样,就定位到到底是哪一行代码,导致了CPU过高了。

 

ok,问题解决

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值