获取IIS工作进程崩溃转储
我在ASP.NET应用程序中做的不好。可能是我正在使用的任何数量的CTP库,或者只是没有正确处理某些东西。但是,当我将ASP.NET重新部署到Vista IIS7安装或者服务器的IIS6安装时,IIS辅助进程崩溃。
我已将问题缩小到我的HTTP搜寻器,它是一个多线程的野兽,当被询问时,它会爬行网站以获取有用的信息。启动搜寻器并在顶部重新部署应用程序后,而不是优雅地卸载appDomain并重新加载,IIS工作进程将崩溃(弹出崩溃消息)并继续重新加载应用程序域。
当此崩溃发生时,我在哪里可以找到崩溃转储进行分析?
解决方案
回答
快速搜索发现IISState依赖Windows调试工具,当崩溃发生时需要运行IISState,但是鉴于我们所描述的情况,这应该不是问题,
回答
下载适用于Windows的调试工具:
http://www.microsoft.com/whdc/DevTools/Debugging/default.mspx
Windows调试工具具有脚本(ADPLUS),该脚本可让我们在进程崩溃时创建转储:
http://support.microsoft.com/kb/286350
该命令应类似于(如果我们使用的是IIS6):
cscript adplus.vbs -crash -pn w3wp.exe
此命令会将调试器添加到工作进程。当崩溃发生时,它将生成一个转储(* .DMP文件)。
我们可以在WinDBG中打开它(也包含在Windows调试工具中)。文件>打开崩溃转储...
默认情况下,WinDBG将向我们(在命令行旁边)显示进程崩溃的线程。
在WinDBG中需要做的第一件事是加载.NET Framework扩展:
.loadby sos mscorwks
然后,我们将显示托管的调用堆栈:
!clrstack
如果线程未运行托管代码,则需要检查本机堆栈:
kpn 200
这应该给我们一些想法。要继续进行故障排除,建议我们阅读以下文章:
http://msdn.microsoft.com/en-us/library/ee817663.aspx