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方法进行异步调用的问题.它似乎在网站运行一段时间后停止工作.
对我来说,这表明有些东西没有得到整理,导致它停止工作.在生产中回收应用程序池之后,它将再次开始工作一段时间.
解决方法
我似乎通过以下方式解决了我的问题:
1)设置AJAX被调用以默认只读访问会话状态,设置<%@ Page Language =“C#”Async =“true”EnableSessionState =“ReadOnly”%>在我的AJAX页面的顶部.
2)当我的报告生成器AJAX查询正在运行时,允许对会话状态的读/写访问HttpContext.Current.SetSessionStateBehavior(System.Web.SessionState.SessionStateBehavior.required);
到目前为止,生产似乎已经解决了这个问题.如果在24小时内它仍能顺利运行,我会接受这个答案.
然而,我仍然对直接发生的阻塞行为感到困惑,但只是在发出一定数量的请求之后.
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。