#利用浏览器缓存机制对象网关请求加速
在我们开发过程中, 常常需要用对象存储来存储数据。
对象存储的优点有以下几点:
1. 对象存储与应用服务解耦,浏览器发送请求不会受到请求并发6条的限制。且不会占用应用服务器的资源。
2. 对象存储提供一套成熟的s3-api,提供(分片)上传,(分片)下载,权限,md5检验等完善的接口,开发人员可直接复用。
3. 对象存储依赖于ceph RADOS设计。拥有数据管理,数据冗余等功能。
4. 通过key直接定位到文件,速度非常快
我们开发过程中常常可以灵活的用户提供短暂有效期的文件下载链接,尤其是在图片管理的场景中,非常方便。而由于对s3-api的不熟悉,我们也常常会在开发中有一些性能问题。例如以下情况,我们在一个图集系统中,需要获取图片的链接。
部分同学往往会把获取文件的链接封装成一个方法,往往是这样的:
# 伪代码
def getDownloadUrl(key):expire_time = time.now().add(3600).unix()return getdownloadUrl("GET",key,expire)def getdownloadUrl(method="GET",key:str,expire=0):....return
这里我们获取图片的下载链接时,是当前时间+1个小时。就出现了一个问题:
浏览器做缓存时是通过请求做的缓存,浏览器两次请求一个图片时,获取的token不一致。浏览器会认为两次请求不是同一个。依然会发请求。我们再次打开图片时,浏览器需要重新请求,但是静态资源-图片,并没有发生变化。我们想要第二次请求时使用到上一次请求的结果。只需要把expire_time设置为到整点过期即可通过浏览器的缓存机制,优化我们的系统。
如下:
# 伪代码
def getDownloadUrl(key):expire_time = time.now().unix()expire_time = expire_time-expire_time%3600+3600*2return getdownloadUrl("GET",key,expire)def getdownloadUrl(method="GET",key:str,expire=0):....return
这里为了避免刚申请到token就过期,我们把token的有效期+1个小时。
即可完美解决浏览器的请求缓存无法加载。