Redis的数据穿透、数据击穿与数据雪崩

Redis缓存面临的问题包括数据穿透、数据击穿和数据雪崩。数据穿透是指请求的数据在Redis和数据库都不存在,可能导致数据库被攻击。解决方法包括缓存空结果、用户合法性校验和使用布隆过滤器。数据击穿是热点key过期导致大量请求直接到达数据库,可以通过设置热点数据永不过期或使用互斥锁来缓解。数据雪崩则是大量key同时失效,解决方案包括设置随机失效时间、热点数据均匀分布以及取消热点数据的过期时间。
摘要由CSDN通过智能技术生成

Redis作为目前使用最广泛的缓存,相信大家都不陌生。但是使用缓存并没有这么简单,还要考虑缓存雪崩,缓存击穿,缓存穿透的问题,什么是缓存雪崩,击穿,穿透呢,出现这些问题又怎么解决呢,接下来学习一下吧。


数据穿透

Tips:Redis和数据库均无所要查询数据

当 Redis 和数据库中都没有我们想要的数据时,就需要考虑缓存穿透的问题了。

一般情况下我们会先去 Redis 中查找某资源,Redis 中查不到就去数据库中查,如果在数据库中依然不存在该数据,那么有可能会有人使用大量该数据查询请求攻击数据库,容易造成数据库宕机,这些请求像“穿透”了缓存一样直接打在数据库上,这种现象就叫做缓存穿透。

解决方法

1、缓存空结果

如果系统发现 Redis 及 DB 中都不存在该资源,就缓存空结果一段时间。需要注意哈,这次的失效时间不能设置的太长,否则数据的实效性会产生很大的问题。

2、用户合法性校验

对用户的请求合法性进行校验,拦截恶意重复请求。

3、布隆过滤器

看到这个名词不要慌。简单来说布隆过滤器的用途就是帮助你判断某个值是否存在。举个例子来看下:假设我们现在有一个长度为 9 的 bit 数组,该数组的每个位置上只能保存 1 或者 0,1 标识该位置被占用,

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

Weber77

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

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

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

打赏作者

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

抵扣说明:

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

余额充值