我开发了一个带有报告模块的基于C#
AJAX的系统,由于更复杂的报告需要大约30秒才能运行,我已经内置了并行AJAX调用来报告生成报告的进度.
报告生成器
在报告的开头,我在缓存中创建了一个项目
HttpContext.Current.Cache.Insert(appProgressName, new JSON.ReportProgress(), null, DateTime.Now.AddMinutes(5), Cache.NoSlidingExpiration );
然后在整个报告生成期间定期更新
((JSON.ReportProgress)HttpContext.Current.Cache[appProgressName]).TimesheetsProcessed++;
最后,当报告生成完成后,它将从缓存中删除
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浏览器通过Visual Studio 2010正常工作,但在五个左右的报表请求后停止工作.部署到生产时(使用Windows 2003,IIS6,.net 4.0),将显示相同的行为,显示前几次尝试的报告生成进度,然后不再用于进一步的请求.
当这个问题开始发生时,使用Firebug检查AJAX调用我可以看到,在主AJAX调用(生成报告)完成之前,检查进度的AJAX调用没有完成.
在我的开发机器和生产环境中发生了对进度检查器AJAX方法进行异步调用的问题.它似乎在网站运行一段时间后停止工作.
对我来说,这表明有些东西没有得到整理,导致它停止工作.在生产中回收应用程序池之后,它将再次开始工作一段时间.
最佳答案 它似乎与
Blocked AJAX calls from MVC上的另一个StackOverflow问题有关,该问题通过更改会话行为得到解决.
我似乎通过以下方式解决了我的问题:
1)设置AJAX被调用以默认只读访问会话状态,设置<%@ Page Language =“C#”Async =“true”EnableSessionState =“ReadOnly”%>在我的AJAX页面的顶部.
2)当我的报告生成器AJAX查询正在运行时,允许对会话状态的读/写访问HttpContext.Current.SetSessionStateBehavior(System.Web.SessionState.SessionStateBehavior.Required);
到目前为止,生产似乎已经解决了这个问题.如果在24小时内它仍能顺利运行,我会接受这个答案.
然而,我仍然对直接发生的阻塞行为感到困惑,但只是在发出一定数量的请求之后.