强缓存和弱缓存

强缓存和弱缓存是Web开发中常用的两种缓存机制。

  1. 强缓存(Strong Cache)

    强缓存是指在浏览器发送请求前,先检查本地缓存中是否存在可用的资源副本。如果存在,并且该资源没有过期,服务器将返回一个特定的响应头,告诉浏览器直接使用本地缓存,而不需要向服务器发送请求。这样可以大大减少网络传输,提高页面加载速度和服务性能。

    常见的强缓存响应头有:

    • Expires:指定资源的过期时间,是服务器返回的绝对时间值。
    • Cache-Control:指定资源的缓存控制策略,可以设置max-age(相对时间)或者s-maxage(仅对共享缓存有效)。

    当浏览器再次请求相同的资源时,会根据缓存策略判断是否使用强缓存。如果缓存未过期,浏览器将直接使用本地缓存,不会发送请求到服务器。

  2. 弱缓存(Weak Cache)

    弱缓存是指在浏览器发送请求后,服务器会先验证该资源是否被修改过,如果未被修改,则返回一个特定的响应头,告诉浏览器可以使用本地缓存。但与强缓存不同的是,即使缓存过期了,浏览器仍然会向服务器发送一个请求进行验证。

    常见的弱缓存响应头有:

    • Last-Modified:指定资源的最后修改时间,是服务器返回的绝对时间值。
    • ETag:指定资源的唯一标识符,通常是根据资源内容生成的哈希值。

    当浏览器再次请求相同的资源时,会带上上次获取到的Last-Modified和ETag等信息,服务器会通过这些信息判断资源是否被修改过。如果未修改,则返回一个特定的响应头,告诉浏览器可以使用本地缓存。

总结:
  • 强缓存不需要与服务器交互,直接从本地缓存中获取资源,速度快。
  • 弱缓存需要与服务器交互,通过验证判断资源是否修改,如果未修改则使用本地缓存。
  • 强缓存的优先级高于弱缓存,即如果同时设置了强缓存和弱缓存的响应头,浏览器会首先检查强缓存是否可用。
  • 如果强缓存失效,浏览器会发送请求到服务器进行验证,如果通过验证,则服务器会返回新的资源给浏览器,并在响应头中携带新的缓存策略。
  • 弱缓存通常配合强缓存一起使用,用于提供更细粒度的缓存控制。
相关推荐
迎風吹頭髮5 小时前
Linux内核架构浅谈49-Linux per-CPU页面缓存:热页与冷页的管理与调度优化
linux·缓存·架构
码农多耕地呗6 小时前
力扣146.LRU缓存(哈希表缓存.映射+双向链表数据结构手搓.维护使用状况顺序)(java)
数据结构·leetcode·缓存
洲覆15 小时前
Redis 内存淘汰策略
开发语言·数据库·redis·缓存
此心光明事上练18 小时前
大厂级企业后端:配置变更与缓存失效的自动化处理方案
运维·缓存·自动化
不良人天码星20 小时前
redis的事务,以及watch的原理
数据库·redis·缓存
doris820420 小时前
使用Yum安装Redis
数据库·redis·缓存
Boilermaker199220 小时前
【Redis】哨兵与对脑裂的情况分析
数据库·redis·缓存
摇滚侠21 小时前
Spring Boot 3零基础教程,WEB 开发 内容协商机制 笔记34
java·spring boot·笔记·缓存
2401_837088502 天前
Redis通用命令
数据库·redis·缓存
来旺2 天前
互联网大厂Java面试全解析及三轮问答专项
java·数据库·spring boot·安全·缓存·微服务·面试