Windbg常用命令及场景分析

下载符号

  1. 加入环境变量:
    变量名:_NT_SYMBOL_PATH
    变量值:SRVd:\symhttp://msdl.microsoft.com/download/symbols
  2. 微软提供了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 :查看某个对象的引用关系
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值