缓存异常:缓存雪崩、击穿、穿透

缓存异常:缓存雪崩、击穿、穿透

缓存雪崩

定义

大量的应用请求无法在 Redis 缓存中进行处理,会将这些请求发送到数据库,导致数据库的压力激增,是发生在大量数据同时失效的场景下

原因

1. 缓存中有大量数据同时过期,导致大量请求无法得到处理:
解决方案
  1. 避免给大量的数据设置相同的过期时间,设置时增加一个随机数
  2. 服务降级:非核心数据,直接返回默认值等;核心数据,继续访问缓存,再访问数据库;
2. Redis 缓存实例发生故障宕机了
解决方案
  1. 在业务系统中实现服务熔断或请求限流机制:服务过载时,启动服务熔断机制,暂停或者转移业务应用对缓存服务的访问
  2. 提前预防:通过主从节点的方式构建 Redis 缓存高可靠集群

缓存击穿

定义

针对某个访问非常频繁的热点数据的请求,无法在缓存中进行处理,紧接着,访问该数据的大量请求,一下子都发送到了后端数据库,导致了数据库压力激增,是发生在某个热点数据失效的场景下,和缓存雪崩相比,缓存击穿失效的数据数量要小很多,应对方法也不一样

解决方案

对于访问特别频繁的热点数据,我们就不设置过期时间了。这样一来,对热点数据的访问请求,都可以在缓存中进行处理。

缓存穿透

定义

要访问的数据既不在 Redis 缓存中,也不在数据库中,导致请求在访问缓存时,发生缓存缺失,再去访问数据库时,发现数据库中也没有要访问的数据。

原因

  1. 业务层误操作:缓存中的数据和数据库中的数据被误删除了,所以缓存和数据库中都没有数据;
  2. 恶意攻击:专门访问数据库中没有的数据;
解决方案
  1. 缓存空值或缺省值。
  2. 使用布隆过滤器快速判断数据是否存在,避免从数据库中查询数据是否存在,减轻数据库压力。
  3. 在请求前端进行检测,把恶意请求直接过滤
相关推荐
码农飞哥4 分钟前
互联网大厂Java面试实战:Spring Boot到微服务的技术问答解析
java·数据库·spring boot·缓存·微服务·消息队列·面试技巧
scdifsn1 小时前
动手学深度学习12.4.硬件-笔记&练习(PyTorch)
pytorch·笔记·深度学习·缓存·内存·硬盘·深度学习硬件
寻找沙漠的人4 小时前
Redis 缓存
数据库·redis·缓存
LLLLLindream6 小时前
Redis——达人探店
数据库·redis·缓存
Clockwiseee7 小时前
RCE联系
数据库·redis·缓存·web
添砖Java中7 小时前
深入剖析缓存与数据库一致性:Java技术视角下的解决方案与实践
java·数据库·spring boot·spring·缓存·双写一致性
AllenO.o1 天前
Redis五种数据结构详解
java·数据结构·数据库·redis·缓存
yy鹈鹕灌顶1 天前
Redis 基础详解:从入门到精通
数据库·redis·缓存
程序员buddha2 天前
【代码优化篇】强缓存和协商缓存
缓存
我可是ikun啊2 天前
Redis经典面试题
数据库·redis·缓存