cpu特别高如何定位

答案来源
问题定位的步骤如下:

  • 找到CPU使用率较高的进程
  • 找到CPU使用率最高的线程
  • 查看堆栈信息,定位到相关代码

步骤一、找到耗CPU的进程

执行top -d 1,显示进程运行信息列表。
在这里插入图片描述如上图 ,最耗CPU的进程PID为:11205

步骤二、找到耗CPU的线程

通过上一步,我们确定了是pid=11205的cava_smu进程cpu过高,那么可以通过top -d 1 -p 11205 -H来确认cpu过载的线程tid,如下图所示:

在这里插入图片描述通过以上操作,可以确认tid=11208,11212,11213三个线程的cpu过高。

步骤三、查看堆栈信息,定位相关代码

首先,如果生产环境没有dlv,则可以拷贝对应的dlv到/usr/local/bin下。
接着 dlv attach 11205,确认tid=11208的goroutine 序号,如下图所示:
在这里插入图片描述
在dlv中切换到对应高cpu协程,并查看堆栈
在这里插入图片描述
通过以上操作,可以确认业务底层的栈帧是第6→5帧,business.go:18行的disPatchTask ->business.go:168 行的dispatchIdleTeu方法相关,查看对应版本代码如下:
代码执行到下图中,dispatchIdleTeu返回了错误qferror.ErrNoTeu。
在这里插入图片描述
代码执行到下图中,189行dispatchIdleTeu返回了错误qferror.ErrNoTeu,所以189 if的执行语句192~212无法进入进行,而外层是一个for死循环,则会造成该协程一直占用cpu,导致cpu过载。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值