在高负载下为ASP.NET应用程序提供服务时,IIS崩溃。如何解决?
我正在使用ASP.NET Web应用程序,当我尝试在Visual Studio中调试它时,它似乎可以正常工作。但是,当我模拟重负载时,IIS崩溃而系统日志中没有任何跟踪-log条目是非常通用的,"万维网发布服务意外终止。它已经完成了4次。"
如何从IIS获取更多信息以解决此问题?
解决方案
回答
关键是"没有任何痕迹"。我们需要输入自己的跟踪日志来创建一些聊天记录。然后,我们将能够找到聊天停止的地方。
回答
asp.net进程的崩溃转储应该为我们提供大量信息。
asp.net 2.0的运行状况监视功能也值得一看。
回答
ASP.NET跟踪...
http://www.beansoftware.com/ASP.NET-Tutorials/Tracing-ASP.NET.aspx
回答
下载适用于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/ms954594.aspx