千家信息网

redis如何解决缓存雪崩和穿透

发表于:2025-01-21 作者:千家信息网编辑
千家信息网最后更新 2025年01月21日,本篇内容介绍了"redis如何解决缓存雪崩和穿透"的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!缓存穿
千家信息网最后更新 2025年01月21日redis如何解决缓存雪崩和穿透

本篇内容介绍了"redis如何解决缓存雪崩和穿透"的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

缓存穿透的解决方法:1、把空的数据也缓存起来;2、利用布隆过滤器。2、缓存雪崩的解决方法:1、设置对应热点key永不过期;2、过期时间错开,过期时间使用随机生成,且热点数据的过期时间设置的长一点;3、多缓存结合;4、采购第三方Redis。

本教程操作环境:windows7系统、Redis6版、DELL G3电脑。

Redis缓存穿透和雪崩的解决方法

一、缓存穿透

当用户查询的key在redis中不存在,对应的id在数据库也不存在,此时被非法用户进行攻击,大量的请求会直接打在db上,造成宕机,从而影响整个系统,这种现象称之为缓存穿透。

解决方案一:把空的数据也缓存起来,比如空字符串,空对象,空数组或list,代码如下

if (list != null && list.size() > 0) {     redisOperator.set("subCat:" + rootCatId, JsonUtils.objectToJson(list));} else {     redisOperator.set("subCat:" + rootCatId, JsonUtils.objectToJson(list), 5*60);}

解决方案二:布隆过滤器

布隆过滤器:

判断一个元素是否在一个数组里面,如下图,利用二进制去做的一个存储,占用内存比较小,0 代表不存在,1 代表存在,添加查询效率很快,当保存了一个数值会经过一个算法将对应的值保存到布隆过滤器的集合上的某个位置,某个位置上可能会存在多个key,当传进来一个不存在的key值,和集合进行匹配,如果匹配不上便会返回一个null

缺点:

1、1%的误判率,当有一个key不存在布隆数组中,但是由于这个误判率,在某个情况下回判断这个key存在,当这个数组越长误判率越低,数组越短误判率越高

2、当我们要删除某个key值的时候,是会删除我们的数据库和redis中的内容,但是布隆数组中无法删除,因为数组的某个位置上会存在对个key如果我们要删除的话就是将1变成0,但是会将其中所有的key值都删除

3、代码复杂度也会增加,因为我们要额外去维护一个集合,当我们使用redis集群,布隆过滤器要和redis结合在一起使用

二、Redis缓存雪崩

缓存雪崩:缓存中的数据大批量失效,然后这个使用又要大量的请求进来,但是由于redis中的key全部失效了所有会全部请求到db上,造成宕机

解决方案

1.设置对应热点key永不过期
2.过期时间错开,过期时间使用随机生成,并且热点数据的过期时间设置的长一点,非热点数据可以设置短一点
3.多缓存结合,例如:请求进入,可以现请求redis,当redis中不存在的时候再去请求memcache,如果都没有再去请求db
4.采购第三方Redis(阿里云或者腾讯云上的redis)

"redis如何解决缓存雪崩和穿透"的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注网站,小编将为大家输出更多高质量的实用文章!

缓存 数据 数组 布隆 雪崩 穿透 时间 热点 过滤器 位置 内容 方案 方法 解决方案 代码 代表 情况 数据库 时候 更多 数据库的安全要保护哪些东西 数据库安全各自的含义是什么 生产安全数据库录入 数据库的安全性及管理 数据库安全策略包含哪些 海淀数据库安全审计系统 建立农村房屋安全信息数据库 易用的数据库客户端支持安全管理 连接数据库失败ssl安全错误 数据库的锁怎样保障安全 网络安全的重要性内容 国外软件开发项目设计文件 众所周知 印度软件开发 哪些公司软件开发需要招投标 北京10年软件开发 工资 开发 炒股软件开发 宝山区什么是网络技术分类 网络技术保障岗是什么 我的世界网易版惊变100天服务器号 网络安全的心得体会300 信息安全工程师或网络安全工程师 公司未制定网络安全事件应急预案 天津体彩软件开发 计算机网络技术有效发送速率 dnf正在连接服务器是什么意思 多线程的数据库连接不安全 网络安全技术吧 多方发力网络安全 草皮贴图软件开发 没有从管理转变为服务器 收录网络安全漏洞 数据库期末考试会挂科吗 网络安全专业大学生实习周志 安全生产风险分级数据库 云计算专业和数据库专业哪个好 计算机网络技术考试成绩 国家网络安全保护法实施细则 无锡hpe机架式服务器价格 网络安全工资格证书 武汉思连网络技术有限公司
0