如何设置IHttpAsyncHandler超时?

Adi*_*dir 8 asp.net iis ihttpasynchandler

我试图在web.config文件中设置executionTimeout:

<compilation debug="false" targetFramework="4.5">
<httpRuntime executionTimeout="30"/>
Run Code Online (Sandbox Code Playgroud)

查看IIS管理器请求页面,我可以看到请求在30秒后没有被终止.
我应该在IHttpAsyncHandler中实现一个Timer吗?

Jas*_*der 6

由于显然缺乏对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();
            }
        }
Run Code Online (Sandbox Code Playgroud)

你将需要一个IAsyncResult来使用这种方法,但这是一个既定的模式,你应该没有遇到麻烦.

此外,当您的轮询仍在运行时,当IIS决定回收您的应用池/拆除您的应用域时,您将遇到问题.如果这是您要处理的条件,则可以使用HostingEnvironment.RegisterObject.