什么时候不能调用Application_EndRequest?

时间:2010-09-01 10:28:12

标签: c# .net web-services tcptrace-pocketsoap

我们在IIS 6中托管了一个ASMX Web服务,并且我们的WebMethod之一看到了一些奇怪的行为。在iisreset之后,对特定方法的第一次调用无法返回到客户端,该客户端在60秒后超时。

我已经在Application_BeginRequest文件中引入了Application_EndRequestGlobal.asax.cs。日志记录显示,对于那一个调用,不会调用EndRequest。方法本身的try-finally块表明它正在运行完成。

在此之前,期间和之后还有其他方法请求不显示问题。 TcpTrace显示没有为该方法的第一个请求返回任何回复。

日志还显示,在finally块完成后,为请求提供服务的线程开始提供其他请求。

我想知道可能导致此类行为的原因,以及我如何进一步调试此行为。

2 个答案:

答案 0 :(得分:1)

假设这是完全可重复的,我将从更改方法开始。即我会删除东西,直到它按预期工作。

听起来网络方法本身会导致一些奇怪的次要行为。我猜测它比将两个数字加在一起并返回结果要复杂得多。

此外,我还要密切关注该方法的用途。例如,它是否实例化非托管资源?您是否涉及任何http处理程序或模块,这可能会在第一次执行此方法时出现问题?

通过消除代码直到它起作用,您将确切地找出造成这种情况的原因。

答案 1 :(得分:0)

一些建议: 将您的日志记录置于:         Application_AuthenticateRequest         应用程序错误 看看你是否收到任何错误。

如果这无济于事,请检查您的应用程序域和IIS的事件日志