redis怎么保证数据一致性


当前第2页 返回上一页

其实并没有,在高并发的场景下,会出现这样的情况:数据发生了变更,先删除了缓存,然后去修改数据库。此时还没来得及修改,一个请求过来了,去读缓存,发现缓存空了,去读数据库,读到了准备修改前的旧数据,并且把旧数据放到了缓存。

随后,数据变更程序完成了数据库的修改。那么完了,这个时候发生数据不一致了......

nginx-34.png解决方案:

针对这种情况,可以先把“修改DB”的操作放到一个JVM队列,后面读请求过来之后,“更新缓存”的操作也放进同一个JVM队列,每个队列,对于一个作业线程,按照队列的顺序,依次执行相关操作,这样就可以保证“更新缓存”一定是在DB修改之后,以保证数据一致性,具体如下图所示:

nginx-35.png

以上就是redis怎么保证数据一致性的详细内容,更多文章请关注木庄网络博客

返回前面的内容

相关阅读 >>

Redis分布式锁的正确实现方式介绍

关于Redis事务和pipleline

Redis分片详解

2021年最新Redis面试题大全及答案(收藏)

为什么不用Redis做数据库

Redis数据保存在哪里

Redis注册成window服务的方法介绍

Redis遍历所有key的方法

详解如何安装和配置Redis(linux环境)

Redis怎么清除缓存数据

更多相关阅读请进入《Redis》频道 >>


数据库系统概念 第6版
书籍

数据库系统概念 第6版

机械工业出版社

本书主要讲述了数据模型、基于对象的数据库和XML、数据存储和查询、事务管理、体系结构等方面的内容。



打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...