redis击穿 雪崩 穿透超详细解决方案梳理


Posted in Redis onMarch 17, 2022

Redis击穿

redis缓存击穿是指某一个非常热点的key(即在客户端搜索的比较多的关键字)突然失效了,这时从客户端发送的大量的请求在redis里找不到这个key,就会去数据里找,最终导致数据库压力过大崩掉。

redis击穿 雪崩 穿透超详细解决方案梳理

解决方案:

1.将value的时效设置成永不过期 这种方式非常简单粗暴但是安全可靠。但是非常占用空间对内存消耗也是极大。个人并不建议使用该方法,应该根据具体业务逻辑来操作。

2.使用Timetask做一个定时任务 使用Timetask做定时,每隔一段时间对一些热点key进行数据库查询,将查询出的结果更新至redis中。前条件是不会给数据库过大的压力。

3.通过synchronized+双重检查机制 当发生reids穿透的时候,这时海量请求发送到数据库。这时我们的解决办法是只让只让一个线程去查询这个热点key,其它线程保持阻塞状态(可以让它们sleep几秒)。当这个进入数据库的线程查询出key对应的value时,我们再将其同步至redis的缓存当中,其它线程睡醒以后再重新去redis里边请求数据。

例子:

private static volaite Object obj = new Object();
   public String getValue(String key){
     String value=redis.get(key,String.class);
     if(value==null||StringUtils.isBlank(value){
         synchronized(obj){
         		//进入synchronized以后再去redis里查一遍,防止上一个抢到锁的线程已经更新过了。
                value=redis.get(key,String.class);
                 if(value==null||StringUtils.isBlank(value){
                     value=db.query(key);
                      redis.set(key,value,1000); 
          }
       }
     }    
      return value;
   }

缺点:存在死锁和线程阻塞的风险。

Redis雪崩

指的是当海量的请求去查询多个key时,此时redis缓存中失效或者查不到,然后海量的请求都去都去db查询,从而导致db压力突然飙升崩溃。

出现原因:

1.key同时失效

2.redis本身崩溃了

redis击穿 雪崩 穿透超详细解决方案梳理

解决方案:

1.设置缓存时,随机初始化其失效时间

如果是redis的key同时失效,可采取该办法,具体失效时间根据业务情况决定…

2.将不同的热点key放置到不同的节点上去

因redis一般都是集群部署,将不同的热点key平均的放置到不同节点,也可以有效避免雪崩。

3.将value的时效设置成永不过期

4.使用Timetask做一个定时任务,在失效之前重新刷redis缓存

Redis穿透

因为不良用户恶意频繁查询才会对系统造成很大的问题: key缓存并且数据库不存在,所以每次查询都会查询数据库从而导致数据库崩溃。

(例如:我们在数据库存放的数据其主键都是自增且没有负数的,某些黑客就利用这一点,不断用主键id为-1的参数来发起海量查询请求,导致这些请求在redis中查不到相应的数据,只能去数据库中查询,从而导致数据库崩溃。)

redis击穿 雪崩 穿透超详细解决方案梳理

解决方案:

1.当类似的请求发过来,无论查出什么结果都放入redis缓存

这样解决当他下次再用同一个参数发起请求时,会直接进到redis里边去,不会再进入数据库。

2.拉黑其ip

3.对请求的参数进行合法性校验,在判断其不合法的前提下直接return掉

4.使用布隆过滤器

可以将布隆过滤器理解成一个白名单或者黑名单,它的作用就是判断一个元素是否存在于这个过滤器。

白名单: 过滤器里有数据库中所有的合法的参数key,请求经过布隆过滤器,布隆过滤器判断这个请求的key在不在过滤器,在就放行让请求进入redis,不在就直接return空数据。

redis击穿 雪崩 穿透超详细解决方案梳理

public static void main(String[] args){
	Config config = new Config();
	config.useSingleServer().setAddress("redis://127.0.0.1:6379");
	config.useSingleServer().setPassword("1234");
	//构造Redsson
	RedissonClient redisson = Redisson.create(config);
	RBloomFilter<String> bloomFilter = redisson.getBloomFilter("phoneList");//给我们自己定义的布隆过滤器取名叫phoneList,名字随便取
	//初始化布隆过滤器设置预计元素为100000000L, 误差率为3%
	bloomFilter.tryInit(100000000L,0.03);
	//将10086插入到布隆过滤器中
	bloomFilter.add("10086");
	//判断下面号码是否存在布隆过滤器中
	//false
	System.out.println("123456");
	//true
	System.out.println("10086");
}

缺点:

布隆过滤器可能会造成误判,从而穿透redis进入DB,但是这个误判概率是非常小的。

以上就是redis击穿 雪崩 穿透超详细解决方案梳理的详细内容,更多关于redis 击穿 雪崩 穿透的资料请关注三水点靠木其它相关文章!

Redis 相关文章推荐
Redis6.0搭建集群Redis-cluster的方法
May 08 Redis
Java Socket实现Redis客户端的详细说明
May 26 Redis
解析高可用Redis服务架构分析与搭建方案
Jun 20 Redis
Redis缓存-序列化对象存储乱码问题的解决
Jun 21 Redis
redis使用不当导致应用卡死bug的过程解析
Jul 01 Redis
Redis入门教程详解
Aug 30 Redis
浅谈Redis的keys命令到底有多慢
Oct 05 Redis
Spring Boot实战解决高并发数据入库之 Redis 缓存+MySQL 批量入库问题
Feb 12 Redis
面试分析分布式架构Redis热点key大Value解决方案
Mar 13 Redis
一文搞懂Redis中String数据类型
Apr 03 Redis
Redis实现一个账号只能登录一个设备
Apr 19 Redis
Redis sentinel哨兵集群的实现步骤
Jul 15 Redis
Redis调用Lua脚本及使用场景快速掌握
Redis 的查询很快的原因解析及Redis 如何保证查询的高效
Redis 中使用 list,streams,pub/sub 几种方式实现消息队列的问题
Redis中有序集合的内部实现方式的详细介绍
Mar 16 #Redis
面试分析分布式架构Redis热点key大Value解决方案
分布式架构Redis中有哪些数据结构及底层实现原理
Redis之RedisTemplate配置方式(序列和反序列化)
Mar 13 #Redis
You might like
php的ajax框架xajax入门与试用介绍
2010/12/19 PHP
PHP打开和关闭文件操作函数总结
2014/11/18 PHP
php猴子选大王问题解决方法
2015/05/12 PHP
PHP实现留言板功能的详细代码
2017/03/25 PHP
详解PHP 二维数组排序保持键名不变
2019/03/06 PHP
用ADODB.Stream转换
2007/01/22 Javascript
关于IE、Firefox、Opera页面呈现异同 写脚本很痛苦
2009/08/28 Javascript
js实现广告漂浮效果的小例子
2013/07/02 Javascript
Ajax请求在数据量大的时候出现超时的解决方法
2014/02/27 Javascript
js精美的幻灯片画集特效代码分享
2015/08/29 Javascript
JQuery实现Ajax加载图片的方法
2015/12/24 Javascript
浅析Bootstrip的select控件绑定数据的问题
2016/05/10 Javascript
JQuery点击行tr实现checkBox选中的简单实例
2016/05/26 Javascript
JS常见算法详解
2017/02/28 Javascript
详解Vue 中 extend 、component 、mixins 、extends 的区别
2017/12/20 Javascript
利用chrome浏览器进行js调试并找出元素绑定的点击事件详解
2021/01/30 Javascript
vue 解决移动端弹出键盘导致页面fixed布局错乱的问题
2019/11/06 Javascript
Python入门篇之字典
2014/10/17 Python
python实现简单socket程序在两台电脑之间传输消息的方法
2015/03/13 Python
python对数组进行反转的方法
2015/05/20 Python
python机器人行走步数问题的解决
2018/01/29 Python
django3.02模板中的超链接配置实例代码
2020/02/04 Python
Python虚拟环境virtualenv创建及使用过程图解
2020/12/08 Python
html5 音乐播放器 audio 标签使用概述
2013/07/15 HTML / CSS
移动端解决悬浮层(悬浮header、footer)会遮挡住内容的3种方法
2015/03/27 HTML / CSS
泰海淘:泰国king Power王权免税集团旗下跨境海淘综合型电商
2020/07/26 全球购物
AJAX检测用户名是否存在的方法
2021/03/24 Javascript
钳工实习自我鉴定
2013/09/19 职场文书
元旦文艺汇演主持词
2014/03/26 职场文书
全国优秀辅导员事迹材料
2014/05/14 职场文书
体操比赛口号
2014/06/10 职场文书
项目申请汇报材料
2014/08/16 职场文书
化验室安全管理制度
2015/08/06 职场文书
2016年教师党员创先争优承诺书
2016/03/24 职场文书
python使用opencv对图像添加噪声(高斯/椒盐/泊松/斑点)
2022/04/06 Python
python模拟浏览器 使用selenium进入好友QQ空间并留言
2022/04/12 Python