Redis 缓存穿透、缓存击穿、缓存雪崩

本文介绍了Redis缓存中的三种异常情况:缓存穿透、缓存击穿和缓存雪崩。缓存穿透场景包括黑客攻击和无效ID查询,解决方法包括设置空对象和使用布隆过滤器。缓存击穿主要发生在冷门key被大量访问或热门key过期时,解决方案包括使用分布式锁。缓存雪崩则涉及redis宕机或大量缓存同时失效,处理方式包括搭建Redis集群、限流降级和数据预热。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

场景:高并发(大量)请求,先访问缓存,后访问数据库
缓存穿透:redis和数据库都没查到
缓存击穿:缓存没查到,数据库查到了
缓存雪崩:雪崩==redis或数据库宕机
思考两个问题:
1、什么样的场景会造成上面三种情况?
2、为了避免高并发访问数据库,常用解决方法是什么呢?

缓存穿透

场景:

用户查询id为-1的数据
黑客强行破解密码
一般是收到黑客攻击,所以应该监控,及时添加黑名单

解决方法

方法1、从缓存出发,数据库中不存在,在缓存中创建一个空对象返回给用户(代码维护简单,但是效果不是很好)
此时的空对象要设置过期时间:redisCache.put(Integer.toString(id), null, 60) //过期时间为 60s
方法2、使用缓存自带的布隆过滤器(代码维护比较复杂,效果挺好的)

缓存击穿

场景:

1、一个冷门key,突然被大量用户访问
2、一个热门key,在缓存中时间刚好过期,大量用户并发访问

解决方法

单机环境下:直接使用常用的锁即可(如:Lock、Synchronized等)
分布式环境下可以使用分布式锁,如:基于数据库、基于Redis或者zookeeper 的分布式锁

缓存雪崩

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Rsun04551

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值