Redis与Mysql数据同步解决方案整理

1 篇文章 0 订阅

最近在做一个Redis数据同步到数据库MySQL的功能。


自己想了想,也有大概方案。

1.队列同步,变跟数据2份,使用消息队列,一份给Redis消费,一份给Mysql消费。

2.后台定时任务,定时刷新Redis中信息到数据库。


网上也到处找了下解决方案

方案一:

读: 读redis->没有,读mysql->把mysql数据写回redis

写: 写mysql->成功,写redis。

就是读的话,先读Redis,Redis没有再读数据库,将数据库中的数据放入Redis。

写(增删改),先写数据库,然后写Redis。

可以对此稍微优化,比如要求一致性高的数据,从数据库读,比如金融,交易数据。不要求强一致性的从Reids中读取。

方案二:

基于binlog使用mysql_udf_redis,将数据库中的数据同步到Redis。

方案三:

基于MQ,也就是最上面想到的方式1。

方案四:

官方有个memcached的udf插件,如果不是那么强烈非要redis的话,也可以考虑

方案五:

用POSTGRESQL 替代 Mysql +Redis.

各种方案弊端

但是上面的方案都有各自的弊端。

方案一,明显对于数据量巨大,更新频繁的数据写入无能为力。比如数量巨大,每个变跟状态又很频繁,这样很容易把数据库写挂。

方案二,是使用的mysql的User Defined Function功能,mysql_udf_redis是有人实现的同步数据到Redis的功能,弊端:需要学习成本,而来,第三方的插件不稳定。

方案三:怎么保证到数据库和到Redis中的状态一致性。就是假设一条修改数据,从队列写入到Mysql成功,但是写入到Redis失败,这种如何搞。还有就是需要一个消息队列,使用第三方的比如Kafka,RabbitMq等来实现,管理起来不方便,系统整体稳定性不行,而且只是这么个比较小的箱格数据信息同步。有点杀鸡用牛刀。


其他的方案:

订阅key的变化进行数据库更新,写的时候写2份,一份往Redis写,一份是Redis数据的key网更新队列(也可以直接Reids存)里写,再写个定时程序从更新队列里取时间,根据key取出Redis数据到Mysql.

这个方案,其实和其他的不一样,弊端了,就是占用内存大,因为需要维护一份更新队列。

可以用定时任务,刷Redis中的信息到数据库。先是进行状态比对,状态不一致的放入集合,批量update数据库。


其实也会有写小问题,比如在比对的时候:

1.Redis中的数据状态变跟了,怎么办?我们不可能在比对的时候锁住Redis,200W次循环,这段时间完全可能发生状态变跟。

2.在比对的时候,有人更新了数据库,怎么办?因为有些操作是可以直接更新数据库的。比如更新layoutRow之类的信息。


Redis同步mysql大致有两种同步,第一种是mysql 同步到redis,为了兼容手动在mysql数据库操作的同步,可以解析mysql的binlog,当数据库发生增,删,改时自动同步到redis,
可以使用的库有[open-replicator](GitHub - whitesock/open-replicator: Open Replicator is a high performance MySQL binlog parser written in Java. It unfolds the possibilities that you can parse, filter and broadcast the binlog events in a real time manner.),

如果想同步redis数据到mysql,可以使用
[redis-replicator](leonchen83/redis-replicator)

<dependency>
    <groupId>com.moilioncircle</groupId>
    <artifactId>redis-replicator</artifactId>
    <version>2.3.1</version>
</dependency>



另外分享一篇mysql刷新自动同步到redis的文章,利用mysql的udf函数利用redis的api从mysql同步到redis;利用c++编写redis的函数,利用mysql加载udf,然后采用触发器
自动同步到redis

通过UDF使mysql主动刷新redis缓存



参考的几篇大神的文章:

1. <<缓存更新的套路>>:http://coolshell.cn/articles/17416.html

2. <<分布式系统的事务处理>>:http://coolshell.cn/articles/10910.html

3. <<redis与mysql数据同步代码演示>>:http://www.cnblogs.com/linjiqin/p/3569011.html

  • 2
    点赞
  • 23
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
RedisMySQL是两种不同的数据库系统,它们在数据一致性方面有一些区别和考虑因素。 首先,Redis是一个内存数据库,它提供了快速的读写性能。由于Redis数据存储在内存中,所以在断电或崩溃可能会丢失数据。因此,Redis默认情况下不提供持久性保证,需要通过配置持久化机制(如RDB快照或AOF日志)来确保数据的持久性。这意味着在Redis中的数据可能会因为持久化机制的延迟或错误而与MySQL中的数据不一致。 而MySQL是一个关系型数据库系统,它将数据存储在磁盘上,并提供了事务的支持。MySQL使用ACID(原子性、一致性、隔离性和持久性)来确保数据的一致性。通过使用事务和锁机制,MySQL可以保证在事务提交之前,所有的修改都是原子的,并且对其他事务是隔离的。因此,在MySQL中,数据具有更高的一致性保证。 要实现RedisMySQL之间的数据一致性,可以采取以下几种方法: 1. 通过在应用程序中实现手动同步机制,在修改Redis数据之前先修改MySQL数据。这样可以确保RedisMySQL中的数据保持一致,但会增加代码的复杂性和开销。 2. 使用消息队列或事件驱动机制,将对MySQL的修改操作发送到消息队列中,并由消费者负责将这些操作同步Redis中。这样可以异步地保持RedisMySQL之间的数据一致性,但可能会引入一定的延迟。 3. 定期将MySQL中的数据导入到Redis中,以保持数据同步。可以使用定任务或数据触发器来实现这个过程。 总之,RedisMySQL数据一致性方面有一些差异,需要根据具体的业务需求和性能要求来选择合适的解决方案

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值