Windbg常用命令及场景分析
下载符号
- 加入环境变量:
变量名:_NT_SYMBOL_PATH
变量值:SRVd:\symhttp://msdl.microsoft.com/download/symbols - 微软提供了sos.dll,提供了一系列便于托管代码调试的命令。
sos.dll加载方式如下:
.loadby sos clr 或者 .load sos 加载符号
场景1:卡住
当程序卡住时,分析卡住的原因。
1、~*e !clrstack:查看所有线程的调用栈
2、~0s :切换线程
3、!clrstack:查看当前线程正在执行的调用栈
4、g 继续执行
423顺序多打几次3 看调用堆栈是否在同一方法上。
场景2、CPU高
1、!runaway 查看当前时间所有线程的累计消耗cpu并倒序排序
2、~0s :切换线程
3、!clrstack 查看当前线程正在执行的调用栈
4、g 继续执行
423顺序多打几次3 看调用堆栈是否在同一方法上。
场景3、不断分配内存
内存分析的两个关键点:
1.哪些对象占用了内存?
2.这些对象来自哪里,为什么没被释放?
!dumpheap –stat 统计堆,根据对像类型统计其个数、占用空间大小
!gcroot 000007ff026b4d48 :查看某个对象的引用关系
常用命令
.loadby sos clr / load sos :加载符号
~[threads]s :切换到指定线程
!clrstack :查看当前线程正在执行的调用栈
!dso 对象地址 :查看对象的详细信息
!do :查看当前线程的栈信息
!runaway :查看当前时间所有线程的累计消耗cpu并倒序排序
!dumpheap –stat -mt -min 80000:统计堆,根据对像类型统计其个数、占用空间大小
!gcroot :查看某个对象的引用关系