Redisi缓存的击穿、穿透、雪崩,介绍一下

  1. 缓存击穿

缓存击穿是指在高并发场景下,缓存中的某个 key 失效,此时大量请求同时涌入数据库查询该 key 的数据,导致数据库瞬间压力过大,甚至宕机。缓存击穿的最佳解决方案是使用互斥锁,令只有一个线程可以从数据库中查询出数据,其他线程等待。同时也可以在缓存中设置短期的过期时间,确保缓存在短时间内得到更新。

  1. 缓存穿透

缓存穿透是指在高并发场景下,请求的 key 在缓存和数据库中都没有对应的数据,导致大量请求直接落到数据库上,导致数据库瞬间压力过大,甚至宕机。缓存穿透的解决方案包括使用布隆过滤器对请求进行过滤,将不存在的 key 直接拦截掉;或者设置空值缓存,将请求不存在的 key 在缓存中也做出对应的响应,避免访问数据库。

  1. 缓存雪崩

缓存雪崩是指在某一时刻,缓存中大量的 key 同时失效,导致大量的请求同时涌入数据库,导致数据库瞬间压力过大,甚至宕机。防止缓存雪崩的方法包括使用分布式锁,令缓存失效的过程不会同时发生,同时可以在缓存中设置过期时间的随机偏移量,避免大量缓存同时失效。

相关推荐
折哥的程序人生 · 物流技术专研7 小时前
Java面试85题图解版 · 特别篇:2026后端高频面试题复盘(算法底层逻辑+高并发架构设计全解析,附Java实战代码)
java·网络·数据库·算法·面试
一条泥憨鱼7 小时前
【Redis】数据类型和常用命令
java·数据库·redis·后端·缓存
云烟成雨TD8 小时前
Spring AI Alibaba 1.x 系列【78】沙箱(Sandbox)
java·人工智能·spring
程序员二叉8 小时前
【Java】 异常高频面试题精讲 | 易错点+对比总结
java·开发语言·面试
周航宇JoeZhou8 小时前
JB3-9-SpringAI(二)
java·ai·agent·多智能体·调度·智能体·观察
好家伙VCC8 小时前
Web Components主题热切换方案揭秘
java·前端
慕木沐8 小时前
Google ADK Java 1.0版本 核心机制与实战 Demo
java·开发语言·python
焦虑的说说9 小时前
秒杀系统设计方案
java
许彰午10 小时前
30_Java Stream流操作全解
java·windows·python
qq_25183645710 小时前
基于java Web网络订餐系统设计与实现 源码文档
java·开发语言·前端