使用Windbg寻找高CPU占用线程
来源:互联网 发布:网络弊大于利反方辩词 编辑:程序博客网 时间:2024/06/05 00:18
http://www.programlife.net/windbg-high-cpu-debug.html
在一个任务中使用多线程编程,程序运行一段时间后就占满了CPU,严重拖慢系统运行速度。这里所说的高CPU,意思就是一个线程占用了一个CPU的大部分运行时间,如果是单核的CPU,表现为CPU占用近100%;相应的双核的话一个线程会占到50%的CPU。
我的电脑是双核四线程的CPU,所以当一个线程死循环的时候会占用掉25%的CPU时间。具体表现为:运行程序的最开始表现正常,随后会看到CPU占用上升至25%、50%、75%等。在这样的情况下我用Windbg Attach到目标进程,并通过!runaway命令来列出各线程所耗费的时间。占用时间最多的就是那些假死的线程了,然后~*kb列出各线程的调用栈,分析一下耗费时间长的线程的调用栈基本可以找出问题所在的原因。
回到我的程序,从调用栈上并不能明显看出问题:一个线程“卡”在recv上,另一个“卡”在select上面;但也不应该耗费如此多的CPU时间。再看一下代码,外层有一个while死循环,用于处理Client发过来的数据,问题基本实在这个while循环里面。再后来,仔细阅读代码后发现原因如下:
- 对recv、select之类的函数返回值判断不全,如果出错应当break
- while内部每一次循环之后应当适当的Sleep
这样处理之后,线程占满CPU的问题就得到解决了。由于一些原因,这里没有把实际情况下的一些分析数据贴出来。
P.S. 使用Process Explorer也能简单排查问题线程。双击进程可以查看进程的属性,然后选择“线程”选项卡,双击高CPU的线程就可以看到调用栈了。
0 0
- 使用Windbg寻找高CPU占用线程
- 使用Windbg寻找高CPU占用线程
- 使用Windbg寻找高CPU占用线程
- 使用Windbg寻找高CPU占用线程
- Windbg命令寻找高CPU占用线程
- 用 WinDbg 诊断CPU占用高
- windbg 定位 c# 程序 cpu 占用高问题
- windbg分析进程CPU占用
- Windbg 调试CPU占用过高
- 分析定位占用CPU资源高的JVM线程
- Linux下JAVA线程占用CPU高一点分享
- Linux下JAVA线程占用CPU高一点分享
- WinDbg调试CPU占用高的问题 试验+实战 《第七篇》
- Java 高CPU占用
- sqlServer CPU占用高
- cpu占用高分析
- 使用Windbg简单排查线程 CPU 100%的方法
- 使用Windbg简单排查线程 CPU 100%的方法
- 感知机讲解
- Windows 没有激活会造成 WSUS 控制台打不开
- AFN3.0API调用
- python GIL 全局锁
- 关于线程的问题
- 使用Windbg寻找高CPU占用线程
- 简单计算器
- 解决Eclipse+JDK 32 bit+hadoop 32bit 遇到org.apache.hadoop.io.nativeio.NativeIO$Windows.access0(Ljava/lan
- [Leetcode] 319. Bulb Switcher
- Ignoring query to other database
- IQKeyboardManager
- [java源码分析]HashMap源码分析
- Android中dip、dp、sp、pt和px的区别
- 深入浅出学Hive——Hive优化