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 08 Redis
详解redis分布式锁的这些坑
May 19 Redis
浅谈redis缓存在项目中的使用
May 20 Redis
redis实现的四种常见限流策略
Jun 18 Redis
详解redis在微服务领域的贡献
Oct 16 Redis
Redis之RedisTemplate配置方式(序列和反序列化)
Mar 13 Redis
Redis集群节点通信过程/原理流程分析
Mar 18 Redis
Redis监控工具RedisInsight安装与使用
Mar 21 Redis
Redis如何使用乐观锁(CAS)保证数据一致性
Mar 25 Redis
Redis keys命令的具体使用
Jun 05 Redis
利用Redis实现点赞功能的示例代码
Jun 28 Redis
如何使用注解方式实现 Redis 分布式锁
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
PHP云打印类完整示例
2016/10/15 PHP
PHP使用栈解决约瑟夫环问题算法示例
2017/08/27 PHP
PHP基于pdo的数据库操作类【可支持mysql、sqlserver及oracle】
2018/05/21 PHP
ExtJs的Date格式字符代码
2010/12/30 Javascript
通过jQuery源码学习javascript(二)
2012/12/27 Javascript
javascript间隔定时器(延时定时器)学习 间隔调用和延时调用
2014/01/13 Javascript
基于Jquery实现仿百度百科右侧导航代码附源码下载
2015/11/27 Javascript
轻松掌握JavaScript状态模式
2016/09/07 Javascript
基于jQuery实现顶部导航栏功能
2016/12/27 Javascript
详解javascript中对数据格式化的思考
2017/01/23 Javascript
jQuery插件HighCharts绘制的基本折线图效果示例【附demo源码下载】
2017/03/07 Javascript
axios全局请求参数设置,请求及返回拦截器的方法
2018/03/05 Javascript
vue.js 2.*项目环境搭建、运行、打包发布的详细步骤
2019/05/01 Javascript
微信小程序动态显示项目倒计时
2019/06/20 Javascript
vue-cli或vue项目利用HBuilder打包成移动端app操作
2020/07/29 Javascript
[01:14:41]DOTA2-DPC中国联赛定级赛 iG vs Magma BO3第一场 1月8日
2021/03/11 DOTA
python通过scapy获取局域网所有主机mac地址示例
2014/05/04 Python
pandas.DataFrame.to_json按行转json的方法
2018/06/05 Python
对Xpath 获取子标签下所有文本的方法详解
2019/01/02 Python
关于不懂Chromedriver如何配置环境变量问题解决方法
2019/06/12 Python
使用python制作一个为hex文件增加版本号的脚本实例
2019/06/12 Python
使用Python串口实时显示数据并绘图的例子
2019/12/26 Python
关于ResNeXt网络的pytorch实现
2020/01/14 Python
Python实现栈的方法详解【基于数组和单链表两种方法】
2020/02/22 Python
Python使用Excel将数据写入多个sheet
2020/05/16 Python
Python3合并两个有序数组代码实例
2020/08/11 Python
机械设计职业生涯规划书
2013/12/27 职场文书
黄河象教学反思
2014/02/10 职场文书
巾帼志愿者活动方案
2014/08/17 职场文书
关于元旦的广播稿2016
2015/12/17 职场文书
发言稿之优秀教师篇
2019/09/26 职场文书
MySql 8.0及对应驱动包匹配的注意点说明
2021/06/23 MySQL
面试中老生常谈的MySQL问答集锦夯实基础
2022/03/13 MySQL
HTML5基础学习之文本标签控制
2022/03/25 HTML / CSS
详细介绍Java中的CyclicBarrier
2022/04/13 Java/Android
在 Python 中利用 Pool 进行多线程
2022/04/24 Python