windbg简介

Windbg是在windows平台下,强大的用户态和内核态调试工具。相比较于Visual Studio,它是一个轻量级的调试工具,所谓轻量级指的是它的安装文件大小较小,但是其调试功能,却比VS更为强大。它的另外一个用途是可以用来分析dump数据。哈哈,这是我们最需要的,可以用来分析并发测试场景或生产环境的性能及稳定性问题。它能够通过dump文件轻松的定位到问题根源,学会使用它,将有效提升我们的问题解决能力和效率。

windbg版本和符合表

  1. 不同版本的程序需要对应版本的抓取工具及windbg版本;
    windbg下载地址,x86位版本下载:【微软官方安装版】 x64位版本下载:【微软官方安装版
  2. 符号表是WinDbg关键的“数据库”,WinDbg必须依赖对应的符合表才能分析出问题原因。配置起来也很简单:File->Symbol File Path  将符号表地址粘贴在输入框中,点击确定即可。
    符号表地址:SRV*C:\Symbols*http://msdl.microsoft.com/download/symbols

配置好了以后,就可以使用windbg打开一个dump文件试试看。File->Open Crash Dump (Ctrl + D)

windbg常用命令

命令 说明
.loadby sos clr  加载调试扩展(.NET4.0以下使用mscorwks)
!threadpool or !tp 显示有关托管线程池的信息
~* e!clrstack 显示所有线程的堆栈
~* e!pe 显示发生在所有线程上的最后的异常
!runaway 显示线程耗费的CPU时间
!syncblk 查看程序阻塞
.logopen 记录调试日志
vertarget 查看系统运行时间
.cls 清屏
q 退出当前调试
!analyze -v 详细显示当前异常信息
~0s 切换到指定线程(中间的数字表示线程号)
!clrstack 查看线程的调用堆栈,仅提供托管代码的堆栈跟踪
!printexception 或 !pe 显示当前活动线程上的最后一个异常
!dumpstackobjects 或 !dso 显示在当前堆栈的边界内找到的所有托管对象
!dumpobj <address>或者 !do 显示对象信息,指定任何有效的对象地址,就能查看该对象的内容
!dumparray <address>或者!da 显示数组信息
!gcroot -nostacks <address>    显示对象内存引用;-nostacks 选项将搜索限制为垃圾回收器句柄和 Freachable对象
!dumpheap –stat 查看堆中的所有对象信息,包括类型信息,个数,大小等
!eeheap -gc | -loader 查看托管对象和程序结构在内存中占用情况
.foreach (myobj{!dumpheap -mt 008f4104-short}) {!do ${myobj}} 输出多个对象信息,该命令会对于堆中所有类型为008f4104的对象,依次调用!do命令

注意:

  1. 我们如果调试远程发过来的dump文件,一般需要提供该机器的三个dll文件:sos.dll / clr.dll / mscordacwks.dll,注意32还是64位版本问题;
  2. 注意.NET版本:3.5以下使用 .loadby sos mscorwks ;.NET4.0使用 .loadby sos clr
  3. sos是一个dll,定义了很多针对.net assembly的调试命令,sos.dll针对不同的runtime有不同的版本。如果使用.load命令,需要为sos.dll指定完整路径。

抓取dump文件

所谓的抓取dump,就是对进程的内存创建转储文件。抓取dump有很多方式和工具,我仅介绍自己常使用的,也是非常强大的命令行工具---ProcDump。它不但是绿色免费的、功能强大,而且没有32、64位版本问题,它会根据目标进程的版本自动创建。

下载地址:https://technet.microsoft.com/en-us/sysinternals/dd996900

需要注意两点:

  1. Procdump需要进程已经启动,并且中途不能停止。比如需要抓取IIS的Dump,由于IIS默认会配置在20分钟内没有任何请求的话就会自动结束,因此如果目标程序存在这样的配置,需要暂时将该配置取消。
  2. 在调试问题的时候经常用到的一个命令是!runaway,但是有些时候!runway在ProcDump抓取的dump中提取不出来。解决的方法是将Debug Tools for Windows (windbg)安装目录下的dbghelp.dll拷贝到procdump目录下,然后再运行命令抓取dump。

常用的命令示例(可以使用PID或进程名):

  1. 立刻抓取fulldump
    procdump -ma w3wp.exe
  2. 连续抓取3个dump,时间间隔为2分钟
    procdump -ma -s 120 -n 3 w3wp.exe
  3. 当CPU连续10秒钟超过40%时抓取dump,总计抓取3个dump
    procdump -ma -c 40 -s 10 -n 3 w3wp.exe
  4. 抓取first chance exception,初次发生指定异常时抓取dump
    procdump -ma -e 1 –f SqlException w3wp.exe

我这里都是抓取的fulldump,注意存放dump文件的可用磁盘空间。准备工作做好以后,抓一个dump用windbg看看先

接下来我会以线程阻塞、连接泄露等实例的方式进行展示,待续。。。

补充:抓取Crash dump时,还是需要使用windbg带的命令行---adplus

adplus -crash -pn w3wp.exe -fullonfirst -o d:\dumps
      此命令会通过监视进程w3wp.exe的运行,在当第一次出现异常时记录一次完整的dump

adplus -crash -pn w3wp.exe -o d:\dumps
      该命令也是在w3wp.exe崩溃时记录dump,但这是一个mini dump

【性能诊断】五、并发场景的性能分析(windbg简介及dump抓取)的更多相关文章

  1. Adreno Profiler分析任意安卓游戏特效+抓取资源

    听说可以抓去任意游戏特效..保存下,有空研究 AdrenoProfiler 下载地址 Adreno Profiler分析任意安卓游戏特效+抓取资源 教程

  2. 【性能诊断】六、并发场景的性能分析(windbg案例,大量的内部异常造成CPU飙升)

    在做产品的某个核心模块的性能优化时,发现压到100并发时应用服务器的CPU就飙升至90%以上,50并发以后TPS就基本定格在一个数值上.使用性能监视器收集应用服务器的数据,发现每秒的.NET CLR ...

  3. 【性能诊断】九、并发场景的性能分析(windbg案例,Fist Chance Exception/Crash dump)

          经常会碰到这样的场景,自测及单单点的测试时没有任何问题,但在并发环境或生产环境下有时出现没规律的异常.报错等情况.在代码中增加日志是其中一种解决方式:抓取指定异常时的dump,通过wind ...

  4. 【性能诊断】八、并发场景的性能分析(windbg案例,连接泄露)

    此前遇到一个项目反馈系统宕机问题,摘要描述如下: 系统不定期出现卡死现象,在多个模块不同功能上都出现过,未发现与特定功能相关的明显规律: 当系统出现卡死现象时,新的用户无法登陆系统: 跟踪应用服务器, ...

  5. 【性能诊断】七、并发场景的性能分析(windbg案例,线程阻塞)

    简单整理一个测试Demo,抓取dump并验证,步骤如下: Symbol File Path:SRV*C:\Symbols*http://msdl.microsoft.com/download/symb ...

  6. Golang适合高并发场景的原因分析

    http://blog.csdn.NET/ghj1976/article/details/27996095 典型的两个现实案例: 我们先看两个用Go做消息推送的案例实际处理能力. 360消息推送的数据 ...

  7. 并发-ConcurrentHashMap源码分析

    ConcurrentHashMap 参考: http://www.cnblogs.com/chengxiao/p/6842045.html https://my.oschina.net/hosee/b ...

  8. Ubuntu下用wireshark抓取802.11封包并进行过滤分析

    要用wireshark抓802.11的包 需要在linux下进行. 要在linux下抓802.11的包 需要在linux下安装无线网卡驱动. 所以 在正式抓取之前先把这两样东西搞起来. *没有特殊说明 ...

  9. 【性能诊断】四、单功能场景的性能分析(RedGate,找到同一个客户端的并发请求被串行化问题)

    问题描述: 客户端js连续发起两个异步http请求,请求地址相同,但参数不同:POST http://*.*.*.*/*****/webservice/RESTFulWebService/RESTFu ...

随机推荐

  1. linux下内存泄露检测工具Valgrind介绍

    目前在linux开发一个分析实时路况的应用程序,在联合测试中发现程序存在内存泄露的情况. 这下着急了,马上就要上线了,还好发现了一款Valgrind工具,完美的解决了内存泄露的问题. 推荐大家可以使用 ...

  2. PHP中CURL方法curl_setopt()函数的一些参数

    bool curl_setopt (int ch, string option, mixed value)curl_setopt()函数将为一个CURL会话设置选项.option参数是你想要的设置,v ...

  3. jquery.extend方法

    jquery.extend()用来扩展jquery中方法,实现插件. 1.jQuery.extend函数详细用法! 扩展jQuery静态方法. 1$.extend({ 2test:function() ...

  4. Runtime Complexity of .NET Generic Collection

    Runtime Complexity of .NET Generic Collection   I had to implement some data structures for my compu ...

  5. C文件的格式化工具(astyle)

    工具简介 astyle用于格式化 C,C++,C#, Java等文件,方便将代码风格转变成预期的效果.如改变缩进方式.括号风格等等. 工具的安装 环境 ubuntu 14.04 $apt-get in ...

  6. HBase学习笔记-HBase性能研究(1)

    使用Java API与HBase集群交互时,需要构建HTable对象,使用该对象提供的方法来进行插入/删除/查询等操作.要创建HTable对象,首先要创建一个带有HBase集群信息的配置对象Confi ...

  7. JSP基础——属性保存范围和request对象

    JSP属性保存范围 JSP中提供了四种属性保存范围,分别为page,request,session及application. 1.page范围,指设置的属性只在当前页面有效.通过pageContext ...

  8. (实用篇)php官方微信接口大全(微信支付、微信红包、微信摇一摇、微信小店)

    微信入口绑定,微信事件处理,微信API全部操作包含在这些文件中.内容有:微信摇一摇接口/微信多客服接口/微信支付接口/微信红包接口/微信卡券接口/微信小店接口/JSAPI <?php class ...

  9. JavaScript+HTML,简单的计算器实现

    成功进化到程序猿快一年多了, 还没写过计算器, 正好今天比较闲,随手写了个计算器,最简单的实现,核心是eval()方法,把字符串作为JS代码处理,把输入的信息拼接成字符串,点等号执行代码得到结果,出异 ...

  10. RSA不限长度非对称加密解密C#

    RSA 分段加解密[解决“不正确的长度”的异常] RSA 是常用的非对称加密算法.最近使用时却出现了“不正确的长度”的异常,研究发现是由于待加密的数据超长所致. .NET Framework 中提供的 ...