- 下载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, 这个就不赘述了。
需要注意的是有 WinDbg (X64) 和 WinDbg (X86) 两个, 应该按dmp文件来源的服务器打开。
- 按 Ctrl+D 打开 dmp 文件, 注意直接点那个工具栏上的打开文件的图标是错误的。
- 加载 sos.dll 文件。 这个最好是直接把 dmp 文件来源服务器上的 sos.dll 文件复制过来, 因为这才是最配套的, 自己本机的不一定合用。
复制到自己的 d:\ 之后, 再执行:
.load d:\sos.dll
- 查看线程池:
!threadpool
cpu 占用率 77% , 线程池还是有关系。 - 看看是哪个线程占用 CPU 时间过多。
!runaway
线程: 0, 8, 126, 2, 127 这几个CPU时间比较多。
- 切换线程到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关闭
9、以上是转载,后面再补充一个指令~*e !clrstack
/* 遍历所有线程,并在每个线程上执行’!clrstack(显示堆栈信息)'命令":*/