缓存穿透、缓存击穿、缓存雪崩的概念以及解决方案

缓存穿透、击穿、雪崩 概念 + 解决方案

三者核心区别:

  • 穿透 :数据根本不存在,缓存、数据库都查不到
  • 击穿单个热点 Key过期,流量直接打数据库
  • 雪崩大量 Key 同时过期/ 缓存服务宕机,数据库被打垮

一、缓存穿透

1. 概念

请求查询不存在的数据:缓存中没有 → 去查数据库 → 数据库也没有 → 无法写入缓存每次请求都会绕过缓存直接查库,高并发下数据库压力极大。

典型场景:查询非法 ID(如id=-1)、恶意刷接口。

2. 解决方案

  1. 缓存空值 / 默认值 数据库查询为空时,缓存null或默认值,设置短过期时间(避免长期无效缓存)。
  2. 布隆过滤器提前将所有存在的 Key 存入布隆过滤器,请求先过过滤器:过滤器判定不存在 → 直接返回,不查库。
  3. 接口参数校验 + 限流拦截非法参数,对恶意请求做限流、黑名单。

二、缓存击穿

1. 概念

某个极高并发的热点 Key ,在缓存中恰好过期 ,瞬间所有请求直接打到数据库。特点:单个 Key、高并发、数据真实存在。

典型场景:秒杀商品、热点新闻缓存过期。

2. 解决方案

  1. 互斥锁(分布式锁) 只允许一个线程去数据库查询并更新缓存,其他线程等待,避免并发打库。常用:Redis SETNX、Redisson 分布式锁。
  2. 热点 Key 永不过期 不设置过期时间,通过后台定时任务主动更新缓存。
  3. 过期时间随机化 给热点 Key 加随机偏移量(如60*60 + 随机300秒),避免精准同时过期。

三、缓存雪崩

1. 概念

大量缓存 Key 在同一时间过期 ,或Redis 服务宕机 ,导致所有请求直接涌入数据库,数据库扛不住压力崩溃。特点:批量 Key / 整个缓存层失效、全局流量冲击。

2. 解决方案

  1. 过期时间加随机值批量 Key 不使用固定过期,统一过期时间 + 随机秒,避免集体失效。
  2. 缓存高可用架构Redis 集群、主从、哨兵模式,防止单节点宕机引发雪崩。
  3. 多级缓存本地缓存(Caffeine/Guava)+ 分布式缓存(Redis),本地缓存兜底。
  4. 限流、熔断、降级接口限流,数据库压力过大时熔断,返回降级数据。
  5. 缓存预热服务启动前,提前将热点数据加载到缓存。

快速总结

问题 核心原因 关键特征 核心方案
穿透 数据不存在 缓存、DB 都无 布隆过滤器、缓存空值
击穿 单个热点 Key 过期 高并发、单 Key 分布式锁、永不过期
雪崩 大量 Key / 缓存服务失效 批量 / 全局失效 随机过期、集群、限流
相关推荐
qqxhb13 小时前
47|成本与性能:缓存、批处理、模型路由与降级
缓存·批处理·智能模型路由·多级降级预案·成本预算
叶小鸡18 小时前
Java 篇-项目实战-AI 天机学堂(从 0 到 1)-day5
数据库·redis·缓存
大模型最新论文速读18 小时前
小红书提出 RedKnot:分头处理 kv 缓存,延时降低 60%效果还提升
论文阅读·人工智能·深度学习·机器学习·缓存·自然语言处理
大囚长20 小时前
大模型API的上下文缓存(Contextual Cache)
人工智能·缓存
小二·21 小时前
Redis 7 分布式缓存架构实战
redis·分布式·缓存
一拳一个娘娘腔1 天前
CVE-2026-43284 — Dirty Frag 深度拆解:当零拷贝遇上原地解密,页缓存成了攻击者的画板
linux·缓存
lx188548698961 天前
Redis大Key阻塞:单线程CPU100%的致命陷阱
数据库·redis·缓存
IT策士1 天前
Redis 从入门到精通:位图、HyperLogLog、GEO
数据库·redis·缓存
布局呆星1 天前
Spring Boot + Redis 缓存实战:@Cacheable、序列化踩坑、缓存一致性,一次讲透
spring boot·redis·缓存
努力成为AK大王1 天前
计算机底层核心原理:CPU、总线、缓存与内存深度解析
缓存·内存·cpu