Redis中缓存穿透/击穿/雪崩问题和解决方法


Posted in Redis onDecember 04, 2021

缓存问题

1. 缓存穿透---查不到

缓存穿透是指用户想查询一个数据,发现Redis中没有,也就是缓存没有命中,就向持久性数据库发起查询,发现数据库也没有这个数据,于是查询失败了。

当用户请求很多的情况下,缓存没有命中,数据库也没有数据,会给数据库造成很大的压力,这就是缓存穿透。

Redis中缓存穿透/击穿/雪崩问题和解决方法

解决方案

第一种解决方案:使用布隆过滤器

使用布隆过滤器之后,将存储的数据放入布隆过滤器中,每次数据查询首先查询布隆过滤器,当在过滤器中判断存在时,再到缓存查询,如果没有,再进入数据查询。

如果在布隆过滤器中不存在,则直接返回告诉用户该数据查不到,这样能大大减轻数据库查询压力。

Redis中缓存穿透/击穿/雪崩问题和解决方法

第二种方案:缓存空对象

当数据库数据不存在时,将返回的空对象缓存起来,同时设置一个过期时间,之后在访问数据时,将从缓存中获取,从而保护了数据库。

存在问题:

对空值设置过期时间,会存在更新数据库数据到缓存数据失效的这一段时间,缓存数据有问题(问题在于缓存的空对象数据,由于还没有过期,但此时数据库数据已经更新了),会对要保证数据一致性的业务造成影响。会需要更多的空间来存储更多的控制,造成内存中有大量的空值的键。

2. 缓存击穿---量太大,缓存过期

缓存击穿是指一个热点key,在不停的扛着大量的并发,当key在失效的瞬间,持续的大并发就会穿破缓存,直接请求到数据库。对数据库造成瞬间压力过大。

解决方案

第一种方案:热点数据永不过期

从缓存角度看,没有设置过期时间,就不会存在缓存过期之后产生的问题。

第二种方案:加互斥锁

使用分布式锁,保证对每个key的访问同一时刻只能一个线程去查询后端服务,其他没有获取锁权限的线程则等待即可。

3. 缓存雪崩

缓存雪崩是指在某一个时间段,缓存集中过期失效或者Redis宕机

对于数据库而言,所有请求压力会全部到达数据库,导致数据库调用量暴增,可能也造成数据库宕机的情况

Redis中缓存穿透/击穿/雪崩问题和解决方法

解决方案

第一种方案(预防为主):Redis采用高可用

这种方案的思路就是集群使用,即使一个redis挂掉,其他redis还可以继续服务。

第二种方案(降低发生时所造成的危害):限流降级

这种思路就是在缓存失效后,通过加锁或者队列来控制读取数据库的线程数量让线程在队列排队,控制整体请请求速率。

第三种方案:数据预热

数据预热即是在正式部署服务之前,先访问一遍数据,可以将大部分的数据加载到缓存中,在即将发生大并发之前已经加载不同的key,设置不同的过期时间,让缓存失效的时间更加均匀。

到此这篇关于Redis中缓存穿透/击穿/雪崩问题和解决方法的文章就介绍到这了,更多相关Redis缓存穿透/击穿/雪崩问题内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Redis 相关文章推荐
redis内存空间效率问题的深入探究
May 17 Redis
redis cluster支持pipeline的实现思路
Jun 23 Redis
Redis 常见使用场景
Aug 30 Redis
使用RedisTemplat实现简单的分布式锁
Nov 20 Redis
关于使用Redisson订阅数问题
Jan 18 Redis
分布式架构Redis中有哪些数据结构及底层实现原理
Mar 13 Redis
Redis高可用集群redis-cluster详解
Mar 20 Redis
windows安装 redis 6.2.6最新步骤详解
Apr 26 Redis
Redis 报错 error:NOAUTH Authentication required
May 15 Redis
Redis实现短信验证码登录的示例代码
Jun 14 Redis
一文教你快速生成MySQL数据库关系图
Jun 28 Redis
基于redis+lua进行限流的方法
Jul 23 Redis
linux下安装redis图文详细步骤
Springboot/Springcloud项目集成redis进行存取的过程解析
使用RedisTemplat实现简单的分布式锁
Nov 20 #Redis
redis缓存存储Session原理机制
CentOS8.4安装Redis6.2.6的详细过程
SpringBoot整合Redis入门之缓存数据的方法
Nov 17 #Redis
Window server中安装Redis的超详细教程
You might like
乐信RP2100的电路分析和打磨
2021/03/02 无线电
php中实现进程锁与多进程的方法
2016/09/18 PHP
php检查函数必传参数是否存在的实例详解
2017/08/28 PHP
JavaScript 编程引入命名空间的方法
2007/06/29 Javascript
不懂JavaScript应该怎样学
2008/04/16 Javascript
javascript实现日历控件(年月日关闭按钮)
2012/12/12 Javascript
js控制的回到页面顶端goTop的代码实现
2013/03/20 Javascript
解决javascript:window.close()在chrome,Firefox下失效的问题
2013/05/07 Javascript
jQuery之ajax技术的详细介绍
2013/06/19 Javascript
jQuery中ready事件用法实例
2015/01/19 Javascript
jQuery position() 函数详解以及jQuery中position函数的应用
2015/12/14 Javascript
JS模拟按钮点击功能的方法
2015/12/22 Javascript
微信小程序实现点击按钮修改文字大小功能【附demo源码下载】
2017/12/06 Javascript
vue中v-text / v-html使用实例代码详解
2019/04/02 Javascript
详解Vue-cli3.X使用px2rem遇到的问题
2019/08/09 Javascript
js实现简单的贪吃蛇游戏
2020/04/23 Javascript
Vue 打包体积优化方案小结
2020/05/20 Javascript
win7 下搭建sublime的python开发环境的配置方法
2014/06/18 Python
Python采用raw_input读取输入值的方法
2014/08/18 Python
python数据结构之链表的实例讲解
2017/07/25 Python
python爬取亚马逊书籍信息代码分享
2017/12/09 Python
matplotlib绘制动画代码示例
2018/01/02 Python
python使用epoll实现服务端的方法
2018/10/16 Python
Python字典中的键映射多个值的方法(列表或者集合)
2018/10/17 Python
Python中最大递归深度值的探讨
2019/03/05 Python
python3.x提取中文的正则表达式示例代码
2019/07/23 Python
Python 类的魔法属性用法实例分析
2019/11/21 Python
Pycharm调试程序技巧小结
2020/08/08 Python
HTML5离线应用与客户端存储的实现
2018/05/03 HTML / CSS
美国礼品卡商城: Gift Card Mall
2017/08/25 全球购物
嘻哈珠宝品牌:KRKC&CO
2020/10/19 全球购物
桥梁工程专业求职信
2014/04/21 职场文书
中学生2014国庆节演讲稿:不屈的民族
2014/09/21 职场文书
公司合并协议书范本
2014/09/30 职场文书
优秀团员个人总结
2015/02/26 职场文书
德劲DE1105机评
2022/04/05 无线电