为了账号安全,请及时绑定邮箱和手机立即绑定

分布式的环境下, MySQL和Redis如何保持数据的一致性?

/ 猿问

分布式的环境下, MySQL和Redis如何保持数据的一致性?

linux零基础学习视频 2018-03-05 09:27:25

一台MySQL,一台Redis,两台应用服务器,用户的数据存储持久化在MySQL中,缓存在Redis,有请求的时候从Redis中获取缓存的用户数据,有修改则同时修改MySQL和Redis中的数据。现在问题是:
1. 先保存到MySQL和先保存到Redis都面临着一个保存成功而另外一个保存失败的情况,这样,如何保证MySQL与Redis中的数据同步?
2. 两台应用服务器的并发访问,如何保证数据的安全性?

查看完整描述

6 回答

?
mark_fork

最初级的缓存不一致问题及解决方案:

楼主描述的方案,“先保存到MySQL和先保存到Redis都面临着一个保存成功而另外一个保存失败的情况”会导致 数据库中数据 与 redis中数据不一致的问题。

解决办法

采用 cache aside pattern 并发更新操作的时候可以先删除缓存,然后更新数据库。

此方案下的更新操作情况:

  1. 删除缓存失败,那么不会去执行update操作。

  2. 删除缓存成功,update失败,读请求还是会将旧值写回到redis中。

  3. 删除缓存成功,update成功,读请求会将新值写回到redis中。

复杂情况的解决办法:

一个update操作,在删除缓存成功,但update操作未提交的情况下,读请求会读取数据库中旧的值,至此缓存中是旧值,update后的数据库是新值,这种情况就应该采用异步读写请求队列去解决,简单言之,update请求入队列,读请求入队列,update操作未执行完之前,读操作被阻塞,但是读操作需要while循环 一段时间,因为一旦当前操作的读请求之前还有一个读请求在队列中,很可能前一个读请求已经将update后的新值已经读取到redis当中了。

查看完整回答
2 反对 回复 2018-03-15
?
安卓入门学习视频

缓存只做失效  不做更新

查看完整回答
2 反对 回复 2018-03-05
?
qq_尐逼_03152988

缓存只做失效,不做更新,支持

查看完整回答
反对 回复 2018-03-06
?
安卓软件程序开发入门学习

插入数据导mysql,从redis读取数据,如果redis没有,从mysql读取到redis再从redis取出来

查看完整回答
反对 回复 2018-03-05
?
ajax入门学习视频

Redis只用作cache,写请求只交给MySQL处理。否则你就要自己去解决一个分布式事务的问题,这个目前还没有性价比高的解决方案。如果应用是write heavy的,请使用HBase和Cassandra

查看完整回答
反对 回复 2018-03-05
?
喵喵一只汪

如果要“保证”数据的安全性,那么会带来开销的进一步提升,以至于使用redis带来的性能优势都会丧失。正确的做法是区分不同的业务,使得并不需要“保证”数据一致性的场合,可以使用redis优化。而敏感的场合依然使用mysql

查看完整回答
反对 回复 2018-03-05

添加回答

回复

举报

0/150
提交
取消
意见反馈 邀请有奖 帮助中心 APP下载
官方微信