news 2026/4/16 13:59:24

蓝易云 - 如何使用Redis来防止穿透、击穿和雪崩问题

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
蓝易云 - 如何使用Redis来防止穿透、击穿和雪崩问题

以下内容以企业级系统稳定性治理为目标,围绕 Redis 在高并发场景下对缓存穿透、缓存击穿、缓存雪崩三类核心风险的防控方案进行系统化拆解。内容强调可落地、可复用、可扩展,适用于真实生产环境,而非概念性描述。


一、先把问题说清楚:三类风险的本质差异 🧠

很多系统“抗不住”,并不是 Redis 不行,而是问题类型判断错误,策略选型失误

问题本质对比表(核心认知)

问题类型触发条件直接后果本质风险
缓存穿透查询不存在的数据请求全部落到 DBDB 被无意义请求拖垮
缓存击穿热点 Key 失效瞬间并发请求同时打 DBDB 被瞬时洪峰压垮
缓存雪崩大量 Key 同时失效DB 长时间高压系统级连锁崩溃

一句话总结:
穿透是“查不到”,击穿是“扛不住”,雪崩是“一起死”。


二、Redis 防缓存穿透:先“止血”,再“兜底” 🛡️

1️⃣ 方案一:缓存空对象(最稳妥)

核心思想
当数据库中不存在的数据被访问时,也要明确告诉系统“它不存在”,而不是反复查询。

实现示例(伪代码)
String value = redis.get(key); if (value != null) { return value.equals("NULL") ? null : value; } Object dbData = db.query(key); if (dbData == null) { redis.set(key, "NULL", 60); // 空值缓存 return null; } redis.set(key, dbData, 300); return dbData;
逐行解释说明
  • redis.get(key)
    👉第一道防线,避免不必要的数据库访问

  • "NULL"占位符
    👉 明确告诉系统:该 Key 在 DB 中不存在

  • TTL=60
    👉 空值短生命周期,防止误缓存真实数据

适合:用户 ID、订单号、资源编号等确定性 Key 场景


2️⃣ 方案二:布隆过滤器(高并发利器)

核心思想
在请求进入 Redis 之前,先做一次存在性预判

工作流程(文字版流程图)
请求 → 布隆过滤器 ↓ 不存在 拦截 ↓ 存在 Redis → DB
特点分析表
维度说明
性能O(1),极低内存
准确性可能误判存在,但不会误判不存在
适用黑名单、ID 校验、高并发接口

企业实践中,布隆过滤器 + 空对象缓存是黄金组合。


三、Redis 防缓存击穿:核心是“控并发” ⚙️

关键认知纠偏

击穿不是 Key 失效的问题,而是Key 失效时没有并发治理机制


1️⃣ 方案一:互斥锁(最经典)

实现示例
if (redis.get(key) == null) { if (redis.setnx(lockKey, "1", 10)) { Object data = db.query(key); redis.set(key, data, 300); redis.del(lockKey); return data; } else { Thread.sleep(50); return redis.get(key); } }
详细拆解
  • setnx(lockKey)
    👉只允许一个线程访问 DB

  • 其他线程sleep + 重试
    👉 避免 DB 被并发打穿

  • lockKey TTL
    👉 防止死锁(这是生产级必备)


2️⃣ 方案二:逻辑过期(更高级)

思想升级
Key 不真正过期,而是值中包含过期时间

数据结构示例
{ "data": {...}, "expireTime": 1710000000 }
优势说明
  • 用户请求永远有数据返回

  • 后台线程异步重建缓存

  • 非常适合:首页、配置中心、排行榜


四、Redis 防缓存雪崩:系统级工程问题 🚧

雪崩不是 Redis 的问题,而是架构治理问题


1️⃣ 方案一:TTL 随机化(第一道防线)

int base = 300; int random = new Random().nextInt(60); redis.set(key, value, base + random);
解释说明
  • base
    👉 统一基础过期时间

  • random
    👉 打散失效时间,避免“集体下线”


2️⃣ 方案二:多级缓存(Redis + 本地缓存)

访问顺序
本地缓存 → Redis → 数据库
实战价值
  • Redis 故障 ≠ 系统不可用

  • 明显降低核心链路压力

  • 高可用系统标配


3️⃣ 方案三:限流 + 熔断(兜底策略)

组件作用
限流控制进入 DB 的请求速率
熔断Redis 异常时快速失败
降级返回默认值或静态页

记住一句话:
缓存是加分项,不能成为单点。


五、企业级落地总结(直说结论)✅

  • 穿透:布隆过滤器 + 空值缓存

  • 击穿:互斥锁 / 逻辑过期

  • 雪崩:TTL 随机化 + 多级缓存 + 限流

如果一个系统只用了 Redis,却没有并发治理、失效策略和兜底方案,那不是高性能架构,而是高风险架构

这套方案的价值不在“会不会用 Redis”,而在于——
你是否真正把 Redis 当作“系统稳定性组件”来设计。

如果你需要下一步:
👉结合真实业务 QPS 给出参数级建议,或者
👉画一份完整的缓存防护架构图(可直接用于方案评审)

可以直接继续往下拆。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/15 16:45:31

蓝易云 - Docker中容器的随机命名方式

在 Docker 里,如果你执行 docker run / docker create 时没有显式指定 --name,Docker 就会给容器分配一个可读性更强的随机名称,避免你只能靠一串长 ID 认人(否则运维排障会像“在机房里找一根同色网线”一样费劲)。&a…

作者头像 李华
网站建设 2026/4/16 13:02:18

大数据基于协同过滤算法的淮安文化旅游推荐系统爬虫可视化大屏

文章目录摘要创新点项目简介大数据系统开发流程主要运用技术介绍爬虫核心代码展示结论源码文档获取定制开发/同行可拿货,招校园代理 :文章底部获取博主联系方式!摘要 该系统基于协同过滤算法构建淮安文化旅游推荐系统,结合网络爬虫与数据可视…

作者头像 李华
网站建设 2026/4/16 6:43:04

数论题卡壳?试试点开VibeThinker看看同余方程解法

数论题卡壳?试试点开VibeThinker看看同余方程解法 在准备数学竞赛的深夜,你盯着一道同余方程组题目发愣: 求最小正整数 $ x $,使得 $$ \begin{cases} x \equiv 2 \pmod{3} \ x \equiv 3 \pmod{5} \ x \equiv 2 \pmod{7} \end{ca…

作者头像 李华
网站建设 2026/4/16 12:21:41

低代码测试平台实操:节省50%时间

效率焦虑下的测试新引擎在追求极致交付速度的DevOps时代,软件测试常常成为流程中的瓶颈。测试从业者们深陷于繁重的脚本编写、冗长的环境准备、频繁的回归测试以及跨平台兼容性验证的泥沼中。传统的自动化测试虽然带来了长期收益,但其高昂的学习曲线、漫…

作者头像 李华
网站建设 2026/4/15 21:24:45

导师推荐8个一键生成论文工具,本科生轻松搞定毕业论文!

导师推荐8个一键生成论文工具,本科生轻松搞定毕业论文! AI 工具助力论文写作,告别手忙脚乱 随着人工智能技术的不断进步,越来越多的高校学生开始借助 AI 工具来辅助论文写作。对于本科生而言,撰写毕业论文不仅是学术能…

作者头像 李华