关于c#:获取IIS工作进程崩溃转储

关于c#:获取IIS工作进程崩溃转储

Getting IIS Worker Process Crash dumps

我在ASP.NET应用程序中做的不好。 可能是我正在使用的任何数量的CTP库,或者只是没有正确处理某些东西。 但是,当我将ASP.NET重新部署到Vista IIS7安装或服务器的IIS6安装时,IIS辅助进程崩溃。

我已将问题缩小到我的HTTP搜寻器,它是一个多线程的野兽,当被询问时,它会爬行网站以获取有用的信息。 启动搜寻器并在顶部重新部署应用程序后,而不是优雅地卸载appDomain并重新加载,IIS工作进程将崩溃(弹出崩溃消息)并继续重新加载应用程序域。

发生崩溃时,在哪里可以找到崩溃转储进行分析?


下载适用于Windows的调试工具:
http://www.microsoft.com/whdc/DevTools/Debugging/default.mspx

Windows调试工具具有脚本(ADPLUS),该脚本可让您在进程崩溃时创建转储:
http://support.microsoft.com/kb/286350

该命令应类似于(如果使用的是IIS6):

1
cscript adplus.vbs -crash -pn w3wp.exe

此命令会将调试器附加到工作进程。当崩溃发生时,它将生成一个转储(* .DMP文件)。

您可以在WinDBG中打开它(也包含在Windows调试工具中)。文件>打开崩溃转储...

默认情况下,WinDBG将向您(在命令行旁边)显示进程崩溃的线程。

在WinDBG中需要做的第一件事是加载.NET Framework扩展:

1
.loadby sos mscorwks

然后,您将显示托管调用堆栈:

1
!clrstack

如果线程未运行托管代码,则需要检查本机堆栈:

1
kpn 200

这应该给您一些想法。要继续进行故障排除,建议您阅读以下文章:

http://msdn.microsoft.com/en-us/library/ee817663.aspx


快速搜索找到IISState-它依赖Windows调试工具,当发生崩溃时需要运行,但是考虑到您所描述的情况,这应该不是问题,


您也可以为此使用DebugDiag

一个很好的解释可以在这里找到:

http://blogs.msdn.com/b/tess/archive/2009/03/20/debugging-a-net-crash-with-rules-in-debug-diag.aspx


推荐阅读