用 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

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

需要注意的是有 WinDbg (X64) 和 WinDbg (X86) 两个, 应该按dmp文件来源的服务器打开。
在这里插入图片描述
在这里插入图片描述

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

在这里插入图片描述

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

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

.load d:\sos.dll
在这里插入图片描述

  1. 查看线程池:
    !threadpool
    cpu 占用率 77% , 线程池还是有关系。
    在这里插入图片描述

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

!runaway

线程: 0, 8, 126, 2, 127 这几个CPU时间比较多。
在这里插入图片描述

  1. 切换线程到0:
    ~0 s
    在这里插入图片描述

!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关闭

在这里插入图片描述

————————————————
版权声明:本文为CSDN博主「吉普赛的歌」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/yenange/article/details/62886988

9、以上是转载,后面再补充一个指令
~*e !clrstack /* 遍历所有线程,并在每个线程上执行’!clrstack(显示堆栈信息)'命令":*/

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值