以下是 Redis 缓存穿透、击穿与雪崩的原理及解决方案的深度解析,结合工业级实践整理:


🔍 ‌一、问题原理与区别

问题类型触发条件核心特征危害
缓存穿透查询‌不存在的数据绕过缓存直击数据库,导致无效查询堆积数据库被恶意请求压垮
缓存击穿热点 Key 突然过期高并发请求同时穿透缓存,访问同一热点数据数据库瞬时并发压力激增
缓存雪崩大量 Key 同时失效‌或 Redis 宕机缓存大面积失效,请求集中访问数据库数据库负载过载甚至崩溃

🛡️ ‌二、解决方案详解

1. 缓存穿透(Cache Penetration)
  • 核心思路‌:拦截非法请求,避免穿透到数据库
    • ① 布隆过滤器(Bloom Filter)
      在缓存前加一层布隆过滤器,快速判断数据是否存在(存在误判率,需定期重建)

      // 伪代码示例:查询前先经过布隆过滤器
      if (!bloomFilter.mightContain(key)) return null; // 拦截非法key

    • ② 缓存空对象(Null Caching)
      数据库查询为空时,缓存 key:null 并设置短过期时间(如 5 分钟)
    • ③ 参数校验
      接口层过滤非法参数(如负数 ID、非合规格式)
2. 缓存击穿(Cache Breakdown)
  • 核心思路‌:防止热点 Key 失效时并发访问数据库
    • ① 互斥锁(Mutex Lock)
      使用分布式锁(如 Redisson)确保只有一个线程重建缓存,其他线程阻塞等待
      RLock lock = redisson.getLock("LOCK_PREFIX:" + key);
      lock.lock(); // 加锁
      try {// 二次检查缓存是否存在value = redis.get(key);if (value == null) {value = db.query(key);  // 查数据库redis.setex(key, 300, value); // 重建缓存}
      } finally {lock.unlock(); // 释放锁
      }
      
    • ② 逻辑过期 + 异步刷新
      不设置物理 TTL,后台定时更新热点数据或监听变更主动刷新
    • ③ 永不过期策略
      对极热点数据设置永不过期,通过逻辑控制更新时机
3. 缓存雪崩(Cache Avalanche)
  • 核心思路‌:分散失效时间,提升系统容错性
    • ① 差异化过期时间
      对 Key 的 TTL 添加随机值(如基础 30 分钟 + 随机 0-10 分钟)
      int baseExpire = 1800; // 基础30分钟
      int randomExpire = new Random().nextInt(600); // 随机0-10分钟
      redis.setex(key, baseExpire + randomExpire, value);
      
    • ② 多级缓存架构
      本地缓存(Caffeine) + Redis 分级缓存,避免单点失效
    • ③ 集群高可用
      部署 Redis 哨兵或集群模式,通过主从切换避免服务全宕
    • ④ 熔断降级
      使用 Hystrix 或 Sentinel 在数据库压力暴增时触发熔断

💎 ‌三、方案对比与选型建议

问题优先级方案适用场景注意事项
缓存穿透布隆过滤器 + 空值缓存高频查询不存在的数据(如防爬虫)布隆过滤器需定期重建
缓存击穿分布式锁 + 逻辑过期秒杀、热点新闻等突发流量场景锁粒度要细,避免性能瓶颈
缓存雪崩随机 TTL + 多级缓存大促期间批量缓存失效结合服务降级兜底

实践要点‌:

  • 穿透防御:布隆过滤器拦截 + 空值缓存短过期(避免长期占用内存);
  • 击穿防御:Redisson 锁超时设置(防止死锁),锁等待时间不宜过长;
  • 雪崩防御:监控 Key 失效分布,动态调整随机 TTL 范围。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/pingmian/86355.shtml
繁体地址,请注明出处:http://hk.pswp.cn/pingmian/86355.shtml
英文地址,请注明出处:http://en.pswp.cn/pingmian/86355.shtml

如若内容造成侵权/违法违规/事实不符,请联系英文站点网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

DFX 动态重构的概念和实现

DFX 动态重构的概念和实现 背景介绍 本文内容当前仅限于XILINX或者和XILINX具有相同结构的FPGA器件。 FPGA 技术提供了在现场进行编程和重新编程的灵活性,而无需通过重新制造流程来实现设计修改。动态功能交换(Dynamic Function eXchange, DFX&#x…

hutool 导出数据报错:org.apache.poi.openxml4j.exceptions.OpenXML4JRuntimeException

Excel 导出报错 org.apache.poi.openxml4j.exceptions.OpenXML4JRuntimeException: Fail to save: an error occurs while saving the package : The part /docProps/core.xml failed to be saved in the stream with marshaller org.apache.poi.openxml4j.opc.internal.marsh…

【学习】win 本地部署qwen3

这里写自定义目录标题 环境搭建下载Ollama安装olama修改模型下载位置(可以不设置)通过ollama下载/启动模型常用命令其他 环境搭建 下载Ollama 安装olama 默认安装位置是c盘 安装到指定位置使用以下命令 OllamaSetup.exe /DIR"d:\Ollama"修改…

python的__init__.py

在此之前先确认一个概念是否弄清 模块命名空间 1. 目录结构 假设你有以下结构: testpkg/__init__.pyfool.pymaybe.py内容如下: fool.py # testpkg/fool.py class Fool:passmaybe.py # testpkg/maybe.py class Maybe:pass__init__.py &#xff08…

四核 A53+工业级存储:移远 SC200L 与 pSLC SD NAND 如何重构 T-BOX 性能边界?

博客目录 一、移远 SC200L:T-BOX 的 “智慧大脑”二、米客方德 MKDN064GIL-ZA T-BOX:数据安全的坚固堡垒三、深度协同:拓展 T-BOX 应用边界 在车联网浪潮席卷而来的当下,T-BOX 作为汽车与外界交互的核心枢纽,其性能优劣…

JavaEE-统一功能处理

拦截器 实现强制登录的功能, 后端程序根据Session来判断⽤⼾是否登录, 但是实现⽅法是⽐较⿇烦的 需要修改每个接⼝的处理逻辑 需要修改每个接⼝的返回结果 接⼝定义修改, 前端代码也需要跟着修改 有没有更简单的办法, 统⼀拦截所有的请求, 并进⾏Session校验呢, 这⾥我们学…

vscode运行c++文件和插件的方法

1.运行c文件全过程 VSCode运行C全教程-CSDN博客 按照以上的操作即可完成正常的配置流程。但是在运行我的文件时,总是出现终端和输出混乱的情况,我想要在终端中进行输入输出的话,需要加一个改动:设置--输入Run In Terminal--勾选…

利用云效实现自动化部署gitee仓库中的项目

本文主要介绍如何利用云效 实现Node项目(vue/react....)自动化部署 1.准备工作 Git 仓库【Gitee】 云服务器【华为云】 你的项目 2. 创建目录 服务器上创建两个目录 一个专门用来放压缩包: /home/www/dist (aaa.tgz bbb.tgz&am…

Flink SourceFunction深度解析:数据输入的起点与奥秘

在Flink的数据处理流程中,StreamGraph构建起了作业执行的逻辑框架,而数据的源头则始于SourceFunction。作为Flink数据输入的关键组件,SourceFunction负责从外部数据源读取数据,并将其转换为Flink作业能够处理的格式。深入理解Sour…

LabVIEW 共享变量通讯方式

在LabVIEW 开发中,共享变量(SharedVariable)作为实现数据实时交换的关键技术,广泛应用于 LabVIEW、PLC 编程、分布式 SCADA 系统等领域。解析主流共享变量通讯机制的技术原理、性能特性及工程实践中的选型策略。​ 一、Network -P…

Angular进阶之十二:Chrome DevTools+Angular实战诊断指南

引言 最近有一个工单是说用户在使用我们的系统的时候,如果使用某个页面的次数多了以后浏览器就开始变慢甚至卡死崩溃掉。这个问题明显是提示有内存泄露,今天就由这个问题开始分享一些关于内存泄漏的知识。 一、 Web 应用内存泄漏的危害与易忽略性 危害&…

在云服务器上搭建 MinIO 图片存储服务器及 Spring Boot 整合实现图片上传下载

一、MinIO 核心概念 MinIO 是一个高性能的分布式对象存储服务器,兼容 Amazon S3 API,具有以下特点: 高性能:针对存储和检索优化 轻量级:单个二进制文件即可运行 云原生:支持 Kubernetes 部署 S3 兼容&a…

《深入解析:如何通过CSS集成WebGPU实现高级图形效果》

当CSS的细腻笔触遇上WebGPU的磅礴算力,两者如同命运交织的织工,以代码为丝线,在虚拟空间中编织出超越现实维度的灵境。这场融合不再局限于视觉呈现的革新,而是创造出一种能够与用户情感共鸣、突破物理法则束缚的沉浸式数字体验&am…

R 语言科研绘图 --- 环状图-汇总

在发表科研论文的过程中,科研绘图是必不可少的,一张好看的图形会是文章很大的加分项。 为了便于使用,本系列文章介绍的所有绘图都已收录到了 sciRplot 项目中,获取方式: R 语言科研绘图模板 --- sciRplothttps://mp.…

突破限制:实现页面内精准监听 localStorage 变更

突破限制:实现页面内精准监听 localStorage 变更 一、简介二、示例演示三、StorageEvent重构setItem四、CustomEvent自定义事件同一页面不同模块数据同步五、MessageChannel同一页面不同模块数据同步六、BroadcastChannel多窗口数据同步七、CustomEventBroadcastCha…

牛客AI面试破解电销招聘效率与成本双重难题

在电销行业,高流动性与大规模招聘需求长期困扰企业人力资源管理。传统招聘模式下,HR需应对海量简历筛选、多轮面试协调、主观评估偏差等挑战,导致招聘周期长、成本高、人才匹配度低。如何通过技术手段实现精准筛选与效率提升?牛客…

智慧生产管控数字化平台(源码+文档+讲解+演示)

引言 在全球化和信息化的浪潮中,制造业正面临着前所未有的挑战和机遇。智慧生产管控数字化平台应运而生,旨在通过数字化手段优化生产管控的全流程。本文将详细介绍智慧生产管控数字化平台的核心功能、技术架构以及如何通过开源代码实现二次开发&#xf…

用Tensorflow进行线性回归和逻辑回归(九)

用TensorFlow训练线性和逻辑回归模型 这一节结合前面介绍的所有TensorFlow概念来训练线性和逻辑回归模型,使用玩具数据集。 用TensorFlow训练模型 假如我们指明了数据点和标签的容器,定义了张量操作的损失函数。添加了优化器节点到计算图,…

使用 vue vxe-table 实现复选框禁用,根据行规则来禁用是否允许被勾选选中

使用 vue vxe-table 实现复选框禁用,根据行规则来禁用是否允许被勾选选中 查看官网:https://vxetable.cn 禁用选中 通过 checkMethod 方法控制 checkbox 是否允许用户手动勾选,如果被禁用,可以调用 setCheckboxRow 方法手动设置…

【Linux-网络】深入拆解TCP核心机制与UDP的无状态设计

🎬 个人主页:谁在夜里看海. 📖 个人专栏:《C系列》《Linux系列》《算法系列》 ⛰️ 道阻且长,行则将至 目录 📚引言 📚一、UDP协议 📖 1.概述 📖 2.特点 &#x1…