强缓存和协商缓存

强缓存和协商缓存

缓存分为强缓存和协商缓存。强缓存不过服务器,协商缓存需要过服务器,协商缓存返回的状态码是304。两类缓存机制可以同时存在,强缓存的优先级高于协商缓存。当执行强缓存时,如若缓存命中,则直接使用缓存数据库中的数据,不再进行缓存协商。

强制缓存判断HTTP首部字段:cache-control,Expires。

Expires是一个绝对时间,即服务器时间。浏览器检查当前时间,如果还没到失效时间就直接使用缓存文件。但是该方法存在一个问题:服务器时间与客户端时间可能不一致。因此该字段已经很少使用。

cache-control中的max-age保存一个相对时间。例如Cache-Control: max-age = 484200,表示浏览器收到文件后,缓存在484200s内均有效。 如果同时存在cache-control和Expires,浏览器总是优先使用cache-control。

对比缓存通过HTTP的last-modified,Etag字段进行判断。

last-modified是第一次请求资源时,服务器返回的字段,表示最后一次更新的时间。下一次浏览器请求资源时就发送if-modified-since字段。服务器用本地Last-modified时间与if-modified-since时间比较,如果不一致则认为缓存已过期并返回新资源给浏览器;如果时间一致则发送304状态码,让浏览器继续使用缓存。

Etag:资源的实体标识(哈希字符串),当资源内容更新时,Etag会改变。服务器会判断Etag是否发生变化,如果变化则返回新资源,否则返回304。

回新资源,否则返回304。

相关推荐
后端小张4 小时前
Redis 执行 Lua,能保证原子性吗?
数据库·redis·缓存
TravisBytes5 小时前
用户态缓存:高效数据交互与性能优化
缓存·性能优化
芊言芊语18 小时前
分布式缓存服务Redis版解析与配置方式
redis·分布式·缓存
攻城狮的梦19 小时前
redis集群模式连接
数据库·redis·缓存
无休居士1 天前
【实践】应用访问Redis突然超时怎么处理?
数据库·redis·缓存
.Net Core 爱好者1 天前
Redis实践之缓存:设置缓存过期策略
java·redis·缓存·c#·.net
M-bao1 天前
缓存数据和数据库数据一致性问题
数据库·缓存
AntDreamer1 天前
在实际开发中,如何根据项目需求调整 RecyclerView 的缓存策略?
android·java·缓存·面试·性能优化·kotlin
微刻时光1 天前
Redis集群知识及实战
数据库·redis·笔记·学习·程序人生·缓存
丁总学Java1 天前
如何使用 maxwell 同步到 redis?
数据库·redis·缓存