用 WinDbg 诊断CPU占用高

1. 下载WinDbg , 

http://msdn.microsoft.com/en-us/windows/hardware/gg463009.aspx

我是 win10,  下载了这个:

http://download.microsoft.com/download/6/3/B/63BADCE0-F2E6-44BD-B2F9-60F5F073038E/standalonesdk/SDKSETUP.EXE


2. 安装WinDbg, 这个就不赘述了。

需要注意的是有 WinDbg (X64) 和 WinDbg (X86) 两个, 应该按dmp文件来源的服务器打开。


3. 按 Ctrl+D 打开 dmp 文件, 注意直接点那个工具栏上的打开文件的图标是错误的。



4. 加载 sos.dll 文件。 这个最好是直接把 dmp 文件来源服务器上的 sos.dll 文件复制过来, 因为这才是最配套的, 自己本机的不一定合用。

复制到自己的 d:\ 之后, 再执行:

.load d:\sos.dll

5. 查看线程池:

 !threadpool


cpu 占用率 77% , 线程池还是有关系。

6. 看看是哪个线程占用 CPU 时间过多。

!runaway
线程: 0, 8, 126, 2, 127 这几个CPU时间比较多。

7. 切换线程到0:
~0 s


8. 
!clrstack




STA:   Single-Thread   Apartment,   中文叫单线程套间。就是在COM库初始化的时候创建一个内存结构,然后让它和调用CoInitialize的线程相关联。这个内存结构针对每个线程都会有一个。支持STA的COM对象只能在创建它的线程里被使用,其它线程如果再创建它就会失败。   

MTA:   Mutil-Thread   Apartment,中文叫多线程套间。COM库在进程中创建一个内存结构,这个内存结构在整个进程中只能有一个,然后让它和调用CoInitializeEx的线程相关联。支持MTA的COM对象可以在任意线程里被使用。多有针对它的调用都会被封装成为消息。

0=> 主线程
2=> MTA(Finalizer) 回收线程
6=> 线程池
8=> ZwWaitForSingleObject+0xa 分配大对象引起GC关闭


 



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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值