windbg排查CPU高问题

一:问题描述
之前做的某个项目最近需要验收,程序是由之前同事开发的,后来因为一直没有出现问题所以也没有继续关注,最近有人反馈我们之前的程序占用的CPU比较高,在服务器上一个简单的服务模块占用了14%左右的CPU。而且CPU是持续占用比较高,那就应该是存在某个线程死循环在处理某个业务,所以就使用任务管理器生成了一个dump文件来进行简单的分析。
二、生成dump文件
打开任务管理器---》选择进程--》创建转储文件,会生成一个dump文件

三、分析dump文件
打开windbg,选择File-->Symbol File Path 设置程序的pdb文件和系统的pdb文件,多个pdb文件路径用分号间隔开
打开dump文件,选择File-->Open Crash Dump 加载dmp文件
使用命令  !runaway 查看每个线程的用户态CPU使用的时间

明显可以看到13号线程,占用的时间最多, 
使用命令切换到   ~13s 切换到13号线程

使用命令 kv 查看当前线程的调用堆栈,可以看到线程中使用到了一个封装的网络通讯库,一直在RecvFrom,猜测可能就是此线程在死循环在等待接收数据,中间没有等待时间,根据这个线索,然后继续定位代码模块

找到调用通讯模块库的线程代码。发现确实有一个while循环,继续点进函数里面查看。

函数内部是在不断的调用循环接收客户端数据,查看调用了通讯库的函数声明,最后一个参数就是等待的时间(单位ms),正常如果设置了阻塞等待的时间应该就不会产生如此高的CPU,那么肯定就是该通讯库的该参数无效,

问题大概已经能定位,修改代码,在调用RecvFrom的函数后面,如果没有接收到网络数据就等待10ms。修改服务再次运行,服务的CPU瞬间下去。
————————————————
版权声明:本文为CSDN博主「越老越顽固」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/qq_37103755/article/details/128263801

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值