在高负载下为ASP.NET应用程序提供服务时,IIS崩溃。如何解决?

时间:2020-03-05 18:53:26  来源:igfitidea点击:

我正在使用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