当前位置:Gxlcms > 数据库问题 > 使用Windbg调试StackOverflowException异常

使用Windbg调试StackOverflowException异常

时间:2021-07-01 10:21:17 帮助过:2人阅读

  上网搜索了下Windbg相关的博客,主要从以下两篇文章中受益颇多。

  文1 .NET应用程序调试—原理、工具、方法

  文2 WinDbg-如何抓取dump文件

  Windbg工具下载地址:http://www.microsoft.com/whdc/devtools/debugging/default.aspx

  看完文章后决定使用分析dmp文件的方式来解决这次的问题。

  首先是获取dump文件。虽然用Windows系统自带的任务管理器可以方便地dump文件,但是由于64位系统和32位进程(发生问题的后台程序)的问题,这种方式获得的dmp文件用Windbg分析不出东西,老是会报一些错,所以采用其他方式,比较靠谱的有两种,从上面文章中分别有提到。

  一是文1提到的使用Windows调试工具箱中的ntsd工具,步骤为:1、cmd运行命令“Windows调试工具箱安装目录\x86\tlist”查看所有进程的PID,找到crash进程的id。2、cmd运行命令“Windows调试工具箱安装目录\x86\ntsd -pv -p 进程PID”。3、ntsd界面中运行命令“.dump/mf dmp文件路径”即生成dmp文件。

  二是文2提到的直接使用Windbg来dump文件,打开“Windows调试工具箱安装目录\x86\windbg.exe”,点击File->Attach to a Process->选择crash的进程->点击确定,进到抓取dump的界面,在命令行中输入“.dump -ma dmp文件路径”生成dmp文件。

  注意,这里的操作步骤都需要到发生crash的机器上且要在发生crash后没关闭进程之前去执行;另外这里使用的是x86下的工具箱,具体的选择可参照这篇文章 Windbg 32位版本和64位版本的选择

  拿到dmp文件后就可以用x86版本的Windbg工具打开了。这里简要写几个调试时用到的命令。使用方法文1文2都有提到。

  .sympath 路径

  .symfix+ 路径

  .reload

  .loadby sos clr

  !analyze -v

  !threads

  ~0s

  !clrstack

  这里设置符号路径时最好是程序所在目录,且带有pdb文件。使用!threads获取所有线程的时候,哪个线程发生了Exception会显示出来,使用~0s命令进入线程,使用!clrstack可以看到调用堆栈,从而可以看到问题所在了。

  大致是这样子,我看到了出现问题的代码,原来有个定时事件发生在每天的5.50分,在触发时因为代码问题,会有小概率没把这个下次时间(即明天5.50分)正确设置,导致今天的事件一直处于触发中,而每次定时器轮询是3秒间隔,到8.23分的时候刚好堆栈溢出。

  至此,问题解决。第一次写博客,不怎么会编辑,将就着看先。因为时间不够,内容也不详细,之后慢慢补充完整。

使用Windbg调试StackOverflowException异常

标签:

人气教程排行