![](/img/trans.png)
[英]In what situation Application_EndRequest is called but Application_BeginRequest is not called?
[英]When might Application_EndRequest not be called?
我们在IIS 6中托管了一个ASMX Web服务,并且看到了一些WebMethod
的奇怪行为。 在iisreset
,对特定方法的第一次调用无法返回到客户端,该客户端在60秒后超时。
我已经在Global.asax.cs
文件中引入了Application_BeginRequest
和Application_EndRequest
。 日志记录显示,对于那一个调用,不会调用EndRequest。 方法本身中的try-finally块表明它正在运行完成。
在此之前,期间和之后对其他方法有其他请求,表明没有问题。 TcpTrace显示对该方法的第一个请求没有返回任何回复。
日志还显示,在finally块完成后,为请求提供服务的线程开始提供其他请求。
我想知道可能导致这种行为的原因,以及我如何进一步调试它。
假设这是完全可重复的,我将从更改方法开始。 即我会删除东西,直到它按预期工作。
听起来有一些由Web方法本身引起的奇怪的次要行为。 我猜这比仅仅添加两个数字并返回结果要复杂一些。
此外,我会密切关注该方法的作用。 例如,它是否实例化非托管资源? 您是否涉及任何http处理程序或模块,这可能会在第一次执行此方法时出现问题?
通过消除代码直到它工作,你将弄清楚究竟是什么导致了这一点。
一些建议:将您的日志记录置于:Application_AuthenticateRequest Application_Error,看看您是否收到任何错误。
如果这无济于事,请检查Application Domain和IIS的事件日志
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.