繁体   English   中英

什么时候不能调用Application_EndRequest?

[英]When might Application_EndRequest not be called?

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

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

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

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

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

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

听起来有一些由Web方法本身引起的奇怪的次要行为。 我猜这比仅仅添加两个数字并返回结果要复杂一些。

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

通过消除代码直到它工作,你将弄清楚究竟是什么导致了这一点。

一些建议:将您的日志记录置于:Application_AuthenticateRequest Application_Error,看看您是否收到任何错误。

如果这无济于事,请检查Application Domain和IIS的事件日志

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM