C# 正在阻止AJAX调用

C# 正在阻止AJAX调用,c#,ajax,jquery,.net-4.0,iis-6,C#,Ajax,Jquery,.net 4.0,Iis 6,我开发了一个基于C#AJAX的系统,其中包含一个报告模块,因为运行更复杂的报告大约需要30秒,我构建了一个并行AJAX调用来报告报告生成的进度 报告生成器 在报告开始时,我在缓存中创建了一个项 HttpContext.Current.Cache.Insert(appProgressName, new JSON.ReportProgress(), null, DateTime.Now.AddMinutes(5), Cache.NoSlidingExpiration ); HttpContext.

我开发了一个基于C#AJAX的系统,其中包含一个报告模块,因为运行更复杂的报告大约需要30秒,我构建了一个并行AJAX调用来报告报告生成的进度

报告生成器
在报告开始时,我在缓存中创建了一个项

HttpContext.Current.Cache.Insert(appProgressName, new JSON.ReportProgress(), null, DateTime.Now.AddMinutes(5), Cache.NoSlidingExpiration );
HttpContext.Current.Cache.Remove(appProgressName);
然后在整个报告生成过程中定期更新

((JSON.ReportProgress)HttpContext.Current.Cache[appProgressName]).TimesheetsProcessed++;
最后,当报表生成完成后,它将从缓存中删除

HttpContext.Current.Cache.Insert(appProgressName, new JSON.ReportProgress(), null, DateTime.Now.AddMinutes(5), Cache.NoSlidingExpiration );
HttpContext.Current.Cache.Remove(appProgressName);
报告进度检查程序
然后在浏览器中每隔几秒钟就有一个AJAX调用,该调用在服务器上调用以下web方法

[WebMethod]
public static JSON.ReportProgress ReportProgress()
{
    string appProgressName = User.CurrentId() + "_ReportProgress";

    if ( HttpContext.Current.Cache[appProgressName] != null )
    {
        return (eServices.SIBSv2.JSON.ReportProgress)HttpContext.Current.Cache[appProgressName];
    }

    return null;
}
这样,客户机就可以计算生成报告的过程,并显示更新进度条

Firebug的下图显示它工作正常-初始报告生成请求和随后的进度检查

这段代码最初通过使用开发web浏览器VisualStudio2010运行良好,但在五次左右的报告请求后停止工作。部署到生产环境时(使用Windows 2003、IIS6、.net 4.0)将显示相同的行为,显示最初几次尝试的报告生成进度,然后不再处理进一步的请求

使用Firebug检查AJAX调用当这个问题开始发生时,我可以看到检查进度的AJAX调用在主AJAX调用(生成报告)完成之前不会完成

异步调用progress checker AJAX方法的问题发生在我的开发机器和生产环境上。网站运行一段时间后,它似乎停止工作


对我来说,这表明有些东西没有被整理好,导致它停止工作。在生产上回收应用程序池后,它将重新开始工作一段时间。

它似乎与上的另一个StackOverflow问题有关,该问题通过更改会话行为得到解决

我似乎通过以下方式解决了我的问题:

1)默认情况下,将调用的AJAX设置为对会话状态具有只读访问权限,在我的AJAX页面顶部设置

2)允许在我的报表生成器AJAX查询运行时对会话状态进行读/写访问
HttpContext.Current.SetSessionStateBehavior(System.Web.SessionState.SessionStateBehavior.Required)

到目前为止,在生产中,这似乎已经解决了这个问题。我会接受这个答案,如果在24小时内它仍然运行顺利


然而我仍然对这种阻塞行为感到困惑,这种行为不是立即发生的,而是在发出一定数量的请求之后才发生的。

在Firefox中运行了前五次,你说呢?我想知道您的客户端Ajax调用是什么样子的?你是否继续使用相同的XMLHttpRequest?@matt gibson我在IE、Chrome和Firefox中得到了相同的结果。用于生成前5个左右的报告。在此之后,进度不会更新,因为进度调用直到生成报告后才会完成。而且一次只触发一个进度调用,它会等到调用完成后再进行另一个调用。我想可能没有关系,但似乎没有关系