我试图在web.config文件中设置executionTimeout:
- <compilation debug="false" targetFramework="4.5">
- <httpRuntime executionTimeout="30"/>
查看IIS管理器请求页面,我可以看到请求在30秒后没有被终止.
我应该在IHttpAsyncHandler中实现一个Timer吗?
解决方法
由于显然缺乏对IHttpAsyncHandler超时的内置支持,大概你必须管理自己的超时.也许这是设计上的;毕竟你选择了一个异步模式 – MSFT认为他们试图为你的长期运行任务设置默认超时?
我要做的是使用ThreadPool.RegisterWaitForSingleObject管理您的轮询与适当的超时.这是我用来避免等待永不返回的Web服务的代码示例:
- private const int REQUEST_TIMEOUT = 30000; // miliseconds (30 sec)
- private void CallService()
- {
- try {
- string url = "somewebservice.com";
- WebRequest request = WebRequest.Create(url);
- // Asynchronously fire off the request
- IAsyncResult result = request.BeginGetResponse(new AsyncCallback(MyRoutineThatUsesTheResults),request);
- // Handle timed-out requests
- ThreadPool.RegisterWaitForSingleObject(result.AsyncWaitHandle,new WaitOrTimerCallback(RequestTimeout),request,REQUEST_TIMEOUT,true);
- }
- catch (Exception ex) {
- _logger.Error("Error during web service request.",ex);
- }
- private void RequestTimeout(object state,bool timedOut)
- {
- if (timedOut) {
- WebRequest request = (WebRequest)state;
- _logger.WarnFormat("Request to {0} timed out (> {1} sec)",request.RequestUri.ToString(),REQUEST_TIMEOUT / 1000);
- request.Abort();
- }
- }
你需要一个IAsyncResult才能使用这种方法,但这是一个既定的模式,你不应该在运行样本时遇到麻烦.
此外,当您的轮询仍在运行时,当IIS决定回收您的应用池/拆除您的应用域时,您将遇到问题.如果这是您想要处理的条件,则可以使用HostingEnvironment.RegisterObject.