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 sentinel 频繁主备切换的问题
Apr 12 Redis
Redis遍历所有key的两个命令(KEYS 和 SCAN)
Apr 12 Redis
浅谈Redis在直播场景的实践方案
Apr 27 Redis
Redis延迟队列和分布式延迟队列的简答实现
May 13 Redis
Redis 配置文件重要属性的具体使用
May 20 Redis
SpringBoot 集成Redis 过程
Jun 02 Redis
Redis中缓存穿透/击穿/雪崩问题和解决方法
Dec 04 Redis
分布式Redis Cluster集群搭建与Redis基本用法
Feb 24 Redis
Redis 中使用 list,streams,pub/sub 几种方式实现消息队列的问题
Mar 16 Redis
Redis基本数据类型String常用操作命令
Jun 01 Redis
一文教你快速生成MySQL数据库关系图
Jun 28 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
PHP错误Warning: Cannot modify header information - headers already sent by解决方法
2014/09/27 PHP
在php中设置session用memcache来存储的方法总结
2016/01/14 PHP
PHP的Yii框架中移除组件所绑定的行为的方法
2016/03/18 PHP
php微信公众平台交互与接口详解
2016/11/28 PHP
js 图片等比例缩放代码
2010/05/13 Javascript
JS实现标签页效果(配合css)
2013/04/03 Javascript
Firefox和IE兼容性问题及解决方法总结
2013/10/08 Javascript
jQuery采用连缀写法实现的折叠菜单效果
2015/09/18 Javascript
跟我学习javascript解决异步编程异常方案
2015/11/23 Javascript
JavaScript保留关键字汇总
2015/12/01 Javascript
AngularJS中$http服务常用的应用及参数
2016/08/22 Javascript
JS命令模式例子之菜单程序
2016/10/10 Javascript
Ionic 2 实现列表滑动删除按钮的方法
2017/01/22 Javascript
js module大战
2019/04/19 Javascript
Vue 使用beforeEach实现登录状态检查功能
2019/10/31 Javascript
创建与框架无关的JavaScript插件
2020/12/01 Javascript
vue-video-player 断点续播的实现
2021/02/01 Vue.js
[08:44]DOTA2发布会群星聚首 我们都是刀塔人
2014/03/21 DOTA
ubuntu安装sublime3并配置python3环境的方法
2018/03/15 Python
Python常见字典内建函数用法示例
2018/05/14 Python
python3将视频流保存为本地视频文件
2018/06/20 Python
python使用pygame模块实现坦克大战游戏
2020/03/25 Python
Apache,wsgi,django 程序部署配置方法详解
2019/07/01 Python
Pytorch 实现数据集自定义读取
2020/01/18 Python
tensorflow求导和梯度计算实例
2020/01/23 Python
使用 Python ssh 远程登陆服务器的最佳方案
2020/03/06 Python
python实现双人五子棋(终端版)
2020/12/30 Python
Python利用socket模块开发简单的端口扫描工具的实现
2021/01/27 Python
惠普墨西哥官方商店:HP墨西哥
2016/12/01 全球购物
final, finally, finalize的区别
2012/03/01 面试题
经贸日语专业个人求职信范文
2014/04/29 职场文书
基层党支部公开承诺书
2014/05/29 职场文书
竞聘演讲稿开场白
2014/08/25 职场文书
自愿解除劳动合同协议书
2014/09/11 职场文书
基于Pygame实现简单的贪吃蛇游戏
2021/12/06 Python
Mybatis-Plus进阶分页与乐观锁插件及通用枚举和多数据源详解
2022/03/21 Java/Android