前端中的强缓存与协商缓存

强缓存:是直接从本地缓存中加载资源,不向服务器发起请求,除非过期了。这种方式可以减少网络延迟,提高页面加载速度,但无法保证资源的最新性

复制代码
皮一下 :
不管你咋样,我都不搭理你,除非我真的无聊了,任性不?

协商缓存:会在加载资源时先询问服务器,如果资源未更改,直接从本地缓存加载 ;如果资源已更改,则重新从服务器加载。这种方式可以确保使用最新资源,但可能会增加网络延迟。

复制代码
皮一下 :
每次都看你一眼,你变强了,我们聊一下,否则继续不理你,现实不?

使用场景

强缓存通常用于减少网络延迟,提高页面加载速度,适用于访问量较大且资源变化不频繁的情况。

协商缓存则适用于需要确保始终使用最新资源的情况,适用于资源变化频繁或需要根据用户个性化需求加载不同资源的情况。

常见场景

常见配置

html配置为不缓存(nostore),其余静态资源配置为强缓存 (max-age)。

为什么?

html页面不缓存保证拿到最新资源另外构建工具可以达到有修改的静态资源hash会有变动,没有改动的静态资源hash不变,两者结合能最大限度的增加缓存命中

复制代码
皮一下

不缓存 (死活不理你)
cache-control: nostore

强缓存(按需理你)
cache-control:max-age=2592000

协商缓存(试探性理你
cache-control : nocache
相关推荐
Allen Bright33 分钟前
Redis介绍
数据库·redis·缓存
只是有点小怂2 小时前
缓存冲突(Cache Conflict)
缓存
Allen Bright4 小时前
Redis安装
数据库·redis·缓存
哭哭啼9 小时前
Redis环境部署(主从模式、哨兵模式、集群模式)
数据库·redis·缓存
只是有点小怂12 小时前
受害者缓存(Victim Cache)
缓存
simpleGq14 小时前
Redis知识点整理 - 脑图
数据库·redis·缓存
运维小文15 小时前
服务器硬件介绍
运维·服务器·计算机网络·缓存·硬件架构
日里安15 小时前
8. 基于 Redis 实现限流
数据库·redis·缓存
jerry6091 天前
7天用Go从零实现分布式缓存GeeCache(改进)(未完待续)
分布式·缓存·golang
看山还是山,看水还是。1 天前
Redis 配置
运维·数据库·redis·安全·缓存·测试覆盖率