在高负载下提供ASP.NET应用程序时,IIS崩溃。如何排除故障?

时间:2008-09-15 13:12:55

标签: debugging iis crash

我正在开发一个ASP.NET Web应用程序,当我尝试在Visual Studio中调试它时,它似乎正常工作。但是,当我模拟重负载时,IIS崩溃而没有任何跟踪 - 系统日志中的日志条目非常通用,“万维网发布服务意外终止。它已经完成了4次。” 如何从IIS获取更多信息来解决此问题?

5 个答案:

答案 0 :(得分:4)

下载适用于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

然后,您将显示托管的callstack:

!clrstack

如果线程没有运行托管代码,那么你需要检查本机堆栈:

kpn 200

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

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

答案 1 :(得分:3)

asp.net process的崩溃转储应该为您提供tons of info ..如果您想快速获取有关流程回收原因的一些信息,try this tip from Scott Gu .. asp.net 2.0的Health monitoring功能也值得一看......

答案 2 :(得分:1)

答案 3 :(得分:0)

密钥是“没有任何痕迹”。您需要将自己的跟踪记录放入以创建一些聊天。然后你就能发现喋喋不休的地方了。

答案 4 :(得分:0)

试试这个https://www.leansentry.com/ - 自动诊断服务器问题的轻量级应用程序监控!