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 相关文章推荐
Redis遍历所有key的两个命令(KEYS 和 SCAN)
Apr 12 Redis
redis实现的四种常见限流策略
Jun 18 Redis
redis cluster支持pipeline的实现思路
Jun 23 Redis
Redis三种集群模式详解
Oct 05 Redis
使用RedisTemplat实现简单的分布式锁
Nov 20 Redis
Springboot/Springcloud项目集成redis进行存取的过程解析
Dec 04 Redis
关于使用Redisson订阅数问题
Jan 18 Redis
Redis 操作多个数据库的配置的方法实现
Mar 23 Redis
解决 Redis 秒杀超卖场景的高并发
Apr 12 Redis
Redis实现一个账号只能登录一个设备
Apr 19 Redis
Redis基本数据类型Zset有序集合常用操作
Jun 01 Redis
Redis基本数据类型哈希Hash常用操作命令
Jun 01 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
晶体管单管来复再生式收音机
2021/03/02 无线电
php数组对百万数据进行排除重复数据的实现代码
2010/06/08 PHP
thinkphp5 框架结合plupload实现图片批量上传功能示例
2020/04/04 PHP
jQuery.Validate 使用笔记(jQuery Validation范例 )
2010/06/25 Javascript
js获取元素在浏览器中的绝对位置
2010/07/24 Javascript
浅析JQuery获取和设置Select选项的常用方法总结
2013/07/04 Javascript
JQuery分别取得每行最后一列和最后一行的示例代码
2013/08/18 Javascript
在JavaScript中判断整型的N种方法示例介绍
2014/06/18 Javascript
javascript将浮点数转换成整数的三个方法
2014/06/23 Javascript
Bootstrap实现弹性搜索框
2016/07/11 Javascript
javascript self对象使用详解
2016/10/18 Javascript
bootstrap滚动监控器使用方法解析
2017/01/13 Javascript
jQuery代码实现实时获取时间
2017/01/29 Javascript
vue的安装及element组件的安装方法
2018/03/09 Javascript
node.js连接mysql与基本用法示例
2019/01/05 Javascript
基于vue 动态菜单 刷新空白问题的解决
2020/08/06 Javascript
Vue中使用JsonView来展示Json树的实例代码
2020/11/16 Javascript
python显示生日是星期几的方法
2015/05/27 Python
python @property的用法及含义全面解析
2018/02/01 Python
python实现Windows电脑定时关机
2018/06/20 Python
python之消除前缀重命名的方法
2018/10/21 Python
python3使用matplotlib绘制散点图
2019/03/19 Python
Python将主机名转换为IP地址的方法
2019/08/14 Python
pygame实现五子棋游戏
2019/10/29 Python
基于python获取本地时间并转换时间戳和日期格式
2020/10/27 Python
详解淘宝H5 sign加密算法
2020/08/25 HTML / CSS
英国殿堂级有机护肤品牌:Rodial
2017/04/17 全球购物
Skyscanner香港:机票比价, 平机票和廉价航空机票预订
2020/02/07 全球购物
印度电子产品购物网站:Vijay Sales
2021/02/16 全球购物
外贸业务员的岗位职责
2013/11/23 职场文书
思想品德课教学反思
2014/02/10 职场文书
百年校庆节目主持词
2014/03/27 职场文书
德能勤绩廉个人总结
2015/02/14 职场文书
2015大学迎新标语
2015/07/16 职场文书
浅谈Mysql多表连接查询的执行细节
2021/04/24 MySQL
Python函数对象与闭包函数
2022/04/13 Python