我开发了一个带有报告模块的基于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方法的异步调用的问题。它似乎在网站运行一段时间后停止工作。
对我来说,这表明有些东西没有得到整理,导致它停止工作。在生产中回收应用程序池之后,它将再次开始工作一段时间。
答案 0 :(得分:2)
它似乎与Blocked AJAX calls from MVC上的另一个StackOverflow问题有关,该问题是通过更改会话行为来解决的。
我似乎通过以下方式解决了我的问题:
1)设置AJAX被调用,默认情况下只能访问会话状态,在我的AJAX页面顶部设置<%@ Page Language="C#" Async="true" EnableSessionState="ReadOnly" %>
。
2)当我的报告生成器AJAX查询正在运行时,允许对会话状态进行读/写访问 HttpContext.Current.SetSessionStateBehavior(System.Web.SessionState.SessionStateBehavior.Required);
到目前为止,生产似乎解决了这个问题。如果在24小时内它仍能顺利运行,我会接受这个答案。
然而我仍然对直接发生的阻止行为感到困惑,但只是在发出一定数量的请求之后才会感到困惑。