一、什么是缓存击穿?
缓存击穿:
某一个“热点 Key”在某一时刻失效,大量并发请求同时访问这个 Key,导致请求瞬间全部打到数据库,数据库压力骤增。
为什么叫“击穿”?
缓存是“墙”
热点 Key 是“薄弱点”
一过期 → 并发请求把缓存打穿
二、缓存击穿是怎么发生的?
典型场景(非常真实)
首页商品信息
热门文章
秒杀商品库存
明星用户信息
不是所有 key 失效,而是一个 key 被并发“围殴”
缓存击穿的完整过程
1. 热点 key 到期
2. Redis 返回 miss
3. 高并发请求同时查 DB
4. DB QPS 暴涨
5. 服务线程阻塞
6. 接口超时 / 崩溃
三、如何解决缓存击穿?
同一时间,只允许一个请求去查数据库
一、互斥锁
思路
缓存 miss 时
先抢锁
只有抢到锁的人查 DB
其他请求等待 / 返回旧值
二、热点数据永不过期
Redis key不设置 TTL
value 中带过期时间
三、提前刷新
热点 key
到期前主动更新