我们在IIS 6中托管了一个ASMX Web服务,并且我们的WebMethod
之一看到了一些奇怪的行为。在iisreset
之后,对特定方法的第一次调用无法返回到客户端,该客户端在60秒后超时。
我已经在Application_BeginRequest
文件中引入了Application_EndRequest
和Global.asax.cs
。日志记录显示,对于那一个调用,不会调用EndRequest。方法本身的try-finally块表明它正在运行完成。
在此之前,期间和之后还有其他方法请求不显示问题。 TcpTrace显示没有为该方法的第一个请求返回任何回复。
日志还显示,在finally块完成后,为请求提供服务的线程开始提供其他请求。
我想知道可能导致此类行为的原因,以及我如何进一步调试此行为。
答案 0 :(得分:1)
假设这是完全可重复的,我将从更改方法开始。即我会删除东西,直到它按预期工作。
听起来网络方法本身会导致一些奇怪的次要行为。我猜测它比将两个数字加在一起并返回结果要复杂得多。
此外,我还要密切关注该方法的用途。例如,它是否实例化非托管资源?您是否涉及任何http处理程序或模块,这可能会在第一次执行此方法时出现问题?
通过消除代码直到它起作用,您将确切地找出造成这种情况的原因。
答案 1 :(得分:0)
一些建议: 将您的日志记录置于: Application_AuthenticateRequest 应用程序错误 看看你是否收到任何错误。
如果这无济于事,请检查您的应用程序域和IIS的事件日志