Windbg程序调试系列1-Mex扩展使用总结

最近一直在频繁使用Windbg做线上Dump调试,与微软做Case交流的时候,发现微软CSS团队,用了一个非常效率的Windbg 插件,Mex:

使用介绍:

https://blogs.msdn.microsoft.com/luisdem/2016/07/19/mex-debugging-extension-for-windbg-2/

下载地址:

https://www.microsoft.com/en-us/download/details.aspx?id=53304

下载之后,解压缩,有两个目录,X64和X86,大家根据自己的需要进行加载,目前我们主要用X64。当然也可以直接把这个扩展拷贝到Windbg运行目录中。

这里,我们先show一下Windbg加载mex扩展:

0:000> .load D:\Mex\x64\mex.dll
Mex External 3.0.0.7172 Loaded!

当然,我们可以同时继续加载sos

0:000> .loadby sos clr

查看已经加载的扩展:

Windbg程序调试系列1-Mex扩展使用总结_第1张图片

如果本机调试Dump,建议设置调试符号的路径:

srv*c:\symcache*http://msdl.microsoft.com/download/symbols;c:\symcache

Windbg程序调试系列1-Mex扩展使用总结_第2张图片

查看Mex的各种命令:

0:000> !mex.help
Mex currently has 255 extensions available.  Please specify a keyword to search.
Or browse by category:

大家可以逐一点进去看一下。

这里我给大家show几个常用的命令:

1. !dae  查看所有的Exception

Windbg程序调试系列1-Mex扩展使用总结_第3张图片

2. 查看所有的线程状态

!mex.mthreads

Windbg程序调试系列1-Mex扩展使用总结_第4张图片

3. !clrstack2 查询线程堆栈

Windbg程序调试系列1-Mex扩展使用总结_第5张图片

4. do2 查看对象

Windbg程序调试系列1-Mex扩展使用总结_第6张图片

5. 查看所有的Asp.Net请求

!mex.aspxpagesext

6. 查看当前线程的异常

!mex.pe2

 7. Foreach

 !foreachobject  -x "!do2 @#Obj"  System.Net.Socket

  

等等,分享给大家。

 

周国庆

2018/7/26

 

你可能感兴趣的:(Windbg程序调试系列1-Mex扩展使用总结)