我已经尝试在web.config文件中设置executionTimeout:
<compilation debug="false" targetFramework="4.5">
<httpRuntime executionTimeout="30"/>查看IIS管理器的请求页面,我可以看到请求在30秒后没有被终止。
我应该在IHttpAsyncHandler中实现一个计时器吗?
发布于 2012-06-01 05:16:45
由于明显缺乏对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。
发布于 2012-05-29 10:48:12
您可以尝试将以下内容添加到web.config文件中:
<system.web>
<pages asyncTimeout="30" />
</system.web>它是为PageAsyncTask设计的,但也可能是为IHttpAsyncHandler而设计的吗?
如果没有,您可能会更幸运地使用ASP.Net 4.5版本中的新HttpTaskAsyncHandler:http://www.asp.net/vnext/overview/whitepapers/whats-new#_Toc318097378
发布于 2012-05-29 19:42:17
您必须使用RegisterAsyncTask检查下面的链接
http://msdn.microsoft.com/en-us/magazine/cc163725.aspx
https://stackoverflow.com/questions/10710104
复制相似问题