缓存刷新校验,head和range校验

370阅读 0评论2017-12-25 oxwangfeng
分类:服务器与存储

当用户purge一个资源的时候,客户经常抱怨资源没有真正的purge干净,依然能够访问到旧资源;对cdn开发着来说,如何提高刷新成功率是非常重要的;

提高刷新成功率,一个最常见的做法就是对刷新的url进行校验,检查是否真正的刷新干净,一般只针对刷新url进行校验,无法对刷新目录进行校验;常见的校验方法有head校验,和range校验,下面说一下这两点的优点和缺点;

head校验。只需要发送head请求就可以,根据响应头中的etag或者last modify检查资源是否是旧的资源;

优点:

这种方法简单,并且对带宽影响可以忽略不计(大部分,与cdn cache实现有关)。

缺点:

1. 有些cdn厂商对head请求做了特殊处理;他们的实现方法是当收到一个head请求,如果是miss,则访问源站,同时会进行backgroud fetch一个完整的资源。这样会导致当发送head请求的时候,无意增加了流量开销,这时候会导致客户抱怨流量徒增了;

2. 有些源站会禁止head请求;不过这个应该是小概率事件了,一般cdn厂商不会这么干;

range校验。一般会发送range请求,range范围可以自定义,只需要校验range范围内的数据即可;

优点:

是对数据校验的一种方法,能够比较准确的校验数据;

缺点:

1. range只对range范围内的数据进行校验,并不一定准确;比如只校验0-4k的数据,可能第4k+1的数据修改导致无法校验成功;

2. 有些cdn厂商对range请求做了特殊处理;他们的实现方法是当收到一个range请求,如果是miss,则访问源站,同时会进行backgroud fetch一个完整的资源。这样会导致当发送range请求的时候,无意增加了流量开销,这时候会导致客户抱怨流量徒增了;

3. 有些源站不支持range,只会返回完整内容,这个虽然不影响校验成功率,但是影响带宽(对于一些较大大文件,校验产生的带宽不容忽视);

所以,可以根据不同的cache实现方法选择不同的校验方法,一般情况下可以选择head校验,如果head校验出问题,可以选择range校验;

上一篇:缓存服务器syns to listen sockets drop导致创建socket失败
下一篇:在golang中使用singleflight实现资源访问合并