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

  1. 缓存击穿

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

  1. 缓存穿透

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

  1. 缓存雪崩

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

相关推荐
coderlin_3 分钟前
Langgraph项目三 agent搭建
java·数据库·redis
xyx-3v6 分钟前
信号量(二进制/计数)
java·linux·数据库
AI人工智能+电脑小能手16 分钟前
【大白话说Java面试题】【Java基础篇】第18题:HashMap底层是如何扩容的
java·开发语言·面试·散列表·hash-index·hash
想躺平的小羊23 分钟前
IDEA 如何显示或关闭项目类的结构(类的方法)
java·ide·intellij-idea
A-Jie-Y29 分钟前
JAVA设计模式-建造者模式
java·设计模式
曹牧38 分钟前
Java Web 开发:servlet-mapping‌
java·数据仓库·hive·hadoop
码云数智-大飞39 分钟前
OpCache 原理深挖:从字节码缓存到预加载(Preloading)的实战配置
java·开发语言
YXWik61 小时前
Claude Code
java
小旭95271 小时前
分布式事务 Seata 详解 + 链路追踪 SkyWalking 实战
java·分布式·后端·信息可视化·skywalking
曹牧1 小时前
Spring:@RequestMapping 注解匹配顺序
java·后端·spring