当前位置 : 主页 > 手机开发 > harmonyos >

用 WinDbg 诊断CPU占用高

来源:互联网 收集:自由互联 发布时间:2023-10-08
下载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 安装WinDbg, 这个


  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文件来源的服务器打开。

用 WinDbg 诊断CPU占用高_线程池


用 WinDbg 诊断CPU占用高_microsoft_02

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

用 WinDbg 诊断CPU占用高_microsoft_03

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

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

.load d:\sos.dll

用 WinDbg 诊断CPU占用高_microsoft_04

  1. 查看线程池:
    !threadpool
    cpu 占用率 77% , 线程池还是有关系。
  2. 用 WinDbg 诊断CPU占用高_windows_05

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

!runaway

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

用 WinDbg 诊断CPU占用高_内存结构_06

  1. 切换线程到0:
    ~0 s
  2. 用 WinDbg 诊断CPU占用高_线程池_07


!clrstack

用 WinDbg 诊断CPU占用高_线程池_08

用 WinDbg 诊断CPU占用高_windows_09

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

用 WinDbg 诊断CPU占用高_windows_10


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


上一篇:DOS命令:跨网段访问设置route
下一篇:没有了
网友评论