缓存一个伴随ASP.NET从1.0到4.0的OutputCache Bug介绍

outputcache  时间:2021-04-18  阅读:()

http://taskcn.blog. 163.com/

一个伴随ASP.NET从1.0到4.0的OutputCache Bug介绍我们先来一睹这个Bug的风采

在一个.aspx文件中增加OutputCache设置代码如下

复制代码代码如下:

%@ OutputCache Duration="300" VaryByParam="*"%

上面的设置表示缓存5分钟根据不同的查询字符串更新缓存。 Location使用的是默认值Any也就是可以在浏览器、代理服务器、 Web服务器三个地方进行缓存在Response Headers中的体现就是Cache-Control:public, max-age=300。 如果你要用CDN加速 Cache-Control就要用public 。

然后我们在Firefox浏览器中访问这个页面并打开Firebug见下图

第一次访问返回状态码为"200 OK"正常。这里Response Headers中的Vary:Accept-Encoding是因为IIS启用“动态内容压缩”产生的如果不启用就不会出现。

这时缓存应该被建立起来了我们按F5刷新一下浏览器看一下结果见下图http://taskcn.blog. 163.com/

http://taskcn.blog. 163.com/

第二次访问返回状态码为"304 Not Modified"浏览器缓存生效这也是我们期望的。

但是请注意一下上图中的Vary:*它会让浏览器的缓存失效我们再按一下F5验证一下。

果然浏览器缓存失效返回状态码变回了200 OK。缓存时间有5分钟呢第三次就失效了这样的结果显然不是我们期望的。

上面的测试是在Web服务器上IIS启用动态内容压缩dynamic contentcompression的情况下进行的如果关闭动态内容压缩每次请求返回都是200 OK Vary都是星号。也就是说浏览器游览缓存根本没起作用。

Bug欣赏完毕我们进行第二个测试。

将OutputCache的VaryByParam属性值设置为none

复制代码代码如下:

%@ OutputCache Duration="600" VaryByParam="none"%http://taskcn.blog. 163.com/

http://taskcn.blog. 163.com/

测试结果显示浏览器第一次请求之后接下来在缓存时间内服务器的响应都是"304 Not Modified"这才是我们想要的效果。

但是在实际应用中我们使用VaryByParam="none"很少用的更多的是为VaryByParam指定对应的值。

所以这个Bug影响很大增加了服务器负担浪费了带宽。

Bug相关信息

在微软的官方文档中专门提到了这个bug——"Output Caching Changes toVary * HTTP Header":

In ASP.NET 1.0, a bug caused cached pages that specified

Location="ServerAndClient" as an output –cache setting to emit aVary:* HTTP header in the response. This had the effect of tellingclient browsers to never cache the page locally.

In ASP.NET 1. 1, the System.Web.HttpCachePolicy.SetOmitVaryStar methodwas added, which you could call to suppress the Vary:* header. Thismethod was chosen because changing the emitted HTTP header wasconsidered a potentially breaking change at the time. However,developers have been confused by the behavior in ASP.NET, and bugreports suggest that developers are unaware of the existing

SetOmitVaryStar behavior.

In ASP.NET 4, the decision was made to fix the root problem. TheVary:* HTTP header is no longer emitted from responses that specifythe following directive:

%@OutputCache Location="ServerAndClient" %

As a result, SetOmitVaryStar is no longer needed in order to suppressthe Vary:* header.http://taskcn.blog. 163.com/

http://taskcn.blog. 163.com/

In applications that specify Location="ServerAndClient" in the @OutputCache directive on a page, you will now see the behaviorimplied by the name of the Location attribute' s value – that is,pages will be cacheable in the browser without requiring that youcall the SetOmitVaryStar method.

从上面的文档中我们可以知道这个Bug的历史

在ASP.NET 1.0时如果在OutputCache中设置

Location="ServerAndClient"在ASP.NET在响应时会浏览器发送Vary:*HTTP header。

在ASP.NET 1. 1时微软针对这个Bug提供一个专门的方法

System.Web.HttpCachePolicy.SetOmitVaryStar(bool omit) 通过

SetOmitVaryStar(true)修改HTTP header去掉Vary:*。

在ASP.NET 4时微软郑重地宣布从根本上解决了这个问题。

而且文档中提到这个bug只会出现在Location="ServerAndClient"时。可是我用ASP.NET 4的实测试情况是不仅Location="ServerAndClient"时的Bug没有解决而且Location="Any"时也会出现同样的Bug。

解决方法

解决方法很简单只要用ASP.NET 1. 1时代提供的

System.Web.HttpCachePolicy.SetOmitVaryStar(bool omit)就能解决问题只需在Page_Load中添加如下代码

复制代码代码如下:protected void Page_Load(object sender, EventArgs e)

{

Response.Cache.SetOmitVaryStar(true) ;

}

相关文档

小结

小bug解决方法也很简单。但是如果你不知道这个bug又会陷入微软的一个骗局之前提到一个WCF Client的 不知不觉中浪费了服务器资源与带宽。

微软那么有钱有那么多天才程序员可是Bug也很难避免可见开发优秀的软件是多么具有挑战性的工作

补充http://taskcn.blog. 163.com/

http://taskcn.blog. 163.com/

ASP.NET MVC中不存在这个问题。http://taskcn.blog. 163.com/

LiCloud:香港CMI/香港CN2+BGP服务器,30Mbps,$39.99/月;香港KVM VPS仅$6.99/月

licloud怎么样?licloud目前提供香港cmi服务器及香港CN2+BGP服务器/E3-1230v2/16GB内存/240GB SSD硬盘/不限流量/30Mbps带宽,$39.99/月。licloud 成立於2021年,是香港LiCloud Limited(CR No.3013909)旗下的品牌,主要提供香港kvm vps,分为精简网络和高级网络A、高级网络B,现在精简网络和高级网络A。现在...

新网,域名7月盛夏1核心2G内存.COM域名仅19.9元/首年,主机9.9元/月,企业邮箱0元体验

新网好不好?新网域名便宜吗?新网怎么样?新网是国内老牌知名域名注册商,企业正规化运营,资质齐全,与阿里云万网和腾讯云DNSPOD同为国内服务商巨头。近日新网发布了最新的七月放价季优惠活动,主要针对域名、云主机、企业邮箱、SSL证书等多款云产品推送了超值的优惠,其中.com顶级域名仅19.9元/首年,.cn域名仅16元/首年,云主机1核心2G内存3Mbps带宽仅9.9元/月,企业邮箱更是免费送1年,...

香港E3 16G 390元/ 香港E5*2 32G 600元/ 香港站群 4-8C 1200元/ 美国200G高防 900/ 日本100M 700元

3C云国内IDC/ISP资质齐全商家,与香港公司联合运营, 已超6年运营 。本次为大家带来的是双12特惠活动,香港美国日本韩国|高速精品|高防|站群|大带宽等产品齐全,欢迎咨询问价。3C云科技有限公司官方网站:http://www.3cccy.com/客服QQ:937695003网页客服:点击咨询客户QQ交流群:1042709810价目表总览升级内存 60元 8G内存升级硬盘 1T机械 90元 2...

outputcache为你推荐
设置xp支持ipad支持ipad支持ipadeaccelerator开启eAccelerator内存优化就各种毛病,DZ到底用哪个内存优化比较好。。。iphone连不上wifi苹果手机“无法加入网络”怎么办谷歌sb为什么搜索SB第一个是google?micromediamacromedia FreeHand MX是干什么用的?联通合约机iphone5联通合约机iphone5和电信合约机Iphone5哪个好google统计怎样将Google分析转换成中文显示Google中文专题交流
英文域名 如何查询ip地址 directspace 新加坡服务器 缓存服务器 一点优惠网 165邮箱 域名和空间 服务器是干什么的 最好的qq空间 新世界服务器 空间购买 东莞主机托管 photobucket lamp的音标 阿里云手机官网 腾讯数据库 宿迁服务器 国外免费网盘 葫芦机 更多