redis数据一致性的实现示例


Posted in Redis onMarch 18, 2022

前言

所谓的redis数据一致性即当进行修改或者保存、删除之后,redis中的数据也应该进行相应变化,不然用户再次查询的时候很可能查询出已经删除过的脏数据。

一、缓存一致的必要性

还是接上篇来说,我们已经解决了redis缓存穿透的问题(简单解决方案,可以再次优化),但是使用redis的时候缓存一致性的问题我们也需要着重考虑,例如:保存了一个新用户之后,就应该同时在redis缓存中也插入该条数据,更新了某条数据在缓存中也应该同步更新,而redis默认的做法是:当你不去设置的时候redis中存放的一值是你之前存放的数据,只有在重启服务器的时候数据才会同步,显然这是非常不可取的,如果是这样的话岂不是每时每刻都要重启服务器,那将是多么大的灾难!

二、业务场景

这里我只说一个场景吧,其他场景都是一样的处理办法,场景为:假设我们将用户数据放入到redis中,此时有新用户注册,在数据库中会插入一条新数据,与此同时要在redis中也插入该条数据,以便于下次查询的时候显示最新数据。

我们先来看一下默认不使用任何处理的情况下redis是否会为我们做一致性操作,现在我的测试数据库中有18条用户数据,此时我们启动系统后注册插入第19条数据后看下redis中是否有19条。

redis数据一致性的实现示例

经过注册之后我现在给数据库中插入了第19条数据

redis数据一致性的实现示例

接着我们还是使用上篇提到过的查询缓存的方法来获取下所有信息,我们直接来看第最后一条,可以看到最后是润青而不是十九,所以redis默认是没有替我们做缓存一致操作的。

redis数据一致性的实现示例

三、缓存一致性实现(方案1)

其实,要想实现一致性很简单,当我们在进行插入操作之后,我们把该条数据取出来同时保存到redis缓存中去,这样再次查询缓存的时候我们也可以看到新的数据,代码如下:

redis数据一致性的实现示例

需要注意的是:我这里直接是调用JPA的findAll(),其实更好的做法是根据id去更新刚插入的那一条,这样效率才高,这里只是演示如何实现,接着再来注册一条新数据,看看是否可以在缓存中同时看到:新插入的数据id为29,我们来看下缓存是否存在该条新数据

redis数据一致性的实现示例

redis数据一致性的实现示例

四、redis缓存一致性实现(方案2)

定期清除redis中的数据,例如设置一个定时任务,每当一个小时的时候就会清除redis中的数据,也就是让redis中的数据失效,然后再次保存、删除的时候之前的 redis中的数据已经不存在,所以相当于是将数据重新设置到redis中去,所以可以保证数据的一致性。

到此这篇关于redis数据一致性的实现示例的文章就介绍到这了,更多相关redis数据一致性内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Redis 相关文章推荐
详解RedisTemplate下Redis分布式锁引发的系列问题
Apr 27 Redis
浅谈Redis主从复制以及主从复制原理
May 29 Redis
Windows下redis下载、redis安装及使用教程
Jun 02 Redis
redis cluster支持pipeline的实现思路
Jun 23 Redis
嵌入式Redis服务器在Spring Boot测试中的使用教程
Jul 21 Redis
Redis读写分离搭建的完整步骤
Sep 14 Redis
详解Redis在SpringBoot工程中的综合应用
Oct 16 Redis
Redis中key的过期删除策略和内存淘汰机制
Apr 12 Redis
Redis实现一个账号只能登录一个设备
Apr 19 Redis
Redis基本数据类型List常用操作命令
Jun 01 Redis
基于redis+lua进行限流的方法
Jul 23 Redis
Redis配置外网可访问(redis远程连接不上)的方法
Dec 24 Redis
高并发下Redis如何保持数据一致性(避免读后写)
Mar 18 #Redis
redis击穿 雪崩 穿透超详细解决方案梳理
Redis调用Lua脚本及使用场景快速掌握
Redis 的查询很快的原因解析及Redis 如何保证查询的高效
Redis 中使用 list,streams,pub/sub 几种方式实现消息队列的问题
Redis中有序集合的内部实现方式的详细介绍
Mar 16 #Redis
面试分析分布式架构Redis热点key大Value解决方案
You might like
php PDO异常处理详解
2016/11/20 PHP
Yii框架创建cronjob定时任务的方法分析
2017/05/23 PHP
解决PHP使用CURL发送GET请求时传递参数的问题
2019/10/11 PHP
JavaScript 基础篇之运算符、语句(二)
2012/04/07 Javascript
checkbox全选所涉及到的知识点介绍
2013/12/31 Javascript
jQuery源码解读之hasClass()方法分析
2015/02/20 Javascript
JS表格组件神器bootstrap table详解(基础版)
2015/12/08 Javascript
jquery获取img的src值的简单实例
2016/05/17 Javascript
NodeJS与HTML5相结合实现拖拽多个文件上传到服务器的实现方法
2016/07/26 NodeJs
ES6正则表达式扩展笔记
2017/07/25 Javascript
20个最常见的jQuery面试问题及答案
2018/05/23 jQuery
解决layui前端框架 form表单,table表等内置控件不显示的问题
2018/08/19 Javascript
vue-cli3.0使用及部分配置详解
2018/08/29 Javascript
JavaScript使用indexOf()实现数组去重的方法分析
2018/09/04 Javascript
javascript设计模式 ? 组合模式原理与应用实例分析
2020/04/14 Javascript
vue组件开发之slider组件使用详解
2020/08/21 Javascript
详解JavaScript中的链式调用
2020/11/27 Javascript
python自动安装pip
2014/04/24 Python
Python2.x版本中maketrans()方法的使用介绍
2015/05/19 Python
web.py 十分钟创建简易博客实现代码
2016/04/22 Python
python实现多人聊天室
2020/03/31 Python
python通过ffmgep从视频中抽帧的方法
2018/12/05 Python
windows下安装Python虚拟环境virtualenvwrapper-win
2019/06/14 Python
python判断两个序列的成员是否一样的实例代码
2020/03/01 Python
Python读取文件内容为字符串的方法(多种方法详解)
2020/03/04 Python
解决 jupyter notebook 回车换两行问题
2020/04/15 Python
一文读懂Python 枚举
2020/08/25 Python
纯CSS3实现滚动的齿轮动画效果
2014/06/05 HTML / CSS
外科实习自我鉴定
2013/10/06 职场文书
市场营销毕业生自荐信
2013/11/23 职场文书
大学生学雷锋活动总结
2014/06/26 职场文书
终止劳动合同证明书样本
2014/11/19 职场文书
法学专业求职信范文
2015/03/19 职场文书
《富饶的西沙群岛》教学反思
2016/02/16 职场文书
iPhone13再次曝光
2021/04/15 数码科技
一文了解MYSQL三大范式和表约束
2022/04/03 MySQL