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 19 Redis
详解Redis瘦身指南
May 26 Redis
redis哨兵常用命令和监控示例详解
May 27 Redis
详解Redis复制原理
Jun 04 Redis
Windows中Redis安装配置流程并实现远程访问功能
Jun 07 Redis
Redis缓存-序列化对象存储乱码问题的解决
Jun 21 Redis
redis使用不当导致应用卡死bug的过程解析
Jul 01 Redis
使用Redis做预定库存缓存功能
Apr 02 Redis
redis 解决库存并发问题实现数量控制
Apr 08 Redis
Redis 异步机制
May 15 Redis
Redis keys命令的具体使用
Jun 05 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
动画 《Pokemon Sword·Shield》系列WEB动画《薄明之翼》第2话声优阵容公开!
2020/03/06 日漫
php 数学运算验证码实现代码
2009/10/11 PHP
php图片加中文水印实现代码分享
2012/10/31 PHP
从零开始学YII2框架(六)高级应用程序模板
2014/08/20 PHP
destoon实现调用图文新闻的方法
2014/08/21 PHP
PHP模拟asp中response类实现方法
2015/08/08 PHP
Zend Framework教程之响应对象的封装Zend_Controller_Response实例详解
2016/03/07 PHP
用php和jQuery来实现“顶”和“踩”的投票功能
2016/10/13 PHP
PHP基于PDO实现的SQLite操作类【包含增删改查及事务等操作】
2017/06/21 PHP
浅谈 javascript 事件处理
2015/01/04 Javascript
基于JavaScript获取鼠标位置的各种方法
2015/12/16 Javascript
利用jQuery设计一个简单的web音乐播放器的实例分享
2016/03/08 Javascript
基于jQuery实现Tabs选项卡自定义插件
2016/11/21 Javascript
利用js获取下拉框中所选的值
2016/12/01 Javascript
Angular中ng-bind和ng-model的区别实例详解
2017/04/10 Javascript
javascript 中的继承实例详解
2017/05/05 Javascript
Vue实现点击后文字变色切换方法
2018/02/11 Javascript
JavaScript实现创建自定义对象的常用方式总结
2018/07/09 Javascript
微信小程序按钮去除边框线分享页面功能
2018/08/27 Javascript
基于vue、react实现倒计时效果
2019/08/26 Javascript
浅析JS中NEW的实现原理及重写
2020/02/20 Javascript
Python实现豆瓣图片下载的方法
2015/05/25 Python
[原创]使用豆瓣提供的国内pypi源
2017/07/02 Python
详解Django中CBV(Class Base Views)模型源码分析
2019/02/25 Python
PyCharm安装Markdown插件的两种方法
2019/06/24 Python
Python简单处理坐标排序问题示例
2019/07/11 Python
Python Unittest原理及基本使用方法
2020/11/06 Python
美国新兴城市生活方式零售商:VILLA
2017/12/06 全球购物
Moda Italia荷兰:意大利男士服装
2019/08/31 全球购物
德国家具、照明、家居用品网上商店:Wayfair.de
2020/02/13 全球购物
应届毕业生个人自我评价
2013/09/20 职场文书
计算机工程学院个人求职信
2013/10/05 职场文书
装修协议书范本
2014/04/21 职场文书
艺术节开幕词
2015/01/28 职场文书
导游词之无锡华莱坞
2019/12/02 职场文书
python3 删除所有自定义变量的操作
2021/04/08 Python