Tungsten Replicator解决异构数据同步的需求

从发现Tungsten Replicator到线上部署,历时4个月。中间也遇到了很多困难,不过在同事的大力配合下,CDC项目(内部名称)已经替代老的事件通知系统,成为网站内部数据更新的重要组成部分。每天处理的数据更新条目数超过200W。

传统的使用Tungsten,是把它作为DB Replication的一部分。但是在互联网架构中,异构数据系统之间如何保持数据的一致性,是架构师面临的普遍挑战。这样的系统在网站里面很多,像检索系统,缓存系统等等。

据说一些网站也在开发类似的技术。因为,以DB为中心的设计思路,决定了业务逻辑严格执行数据“入库为安”的思路。能够写入DB就是成功,写不进去就是失败。这样的策略,以及系统运行的不可靠,决定了在页面逻辑中实现数据的一致性的做法,本身就带有太多的不稳定因素:毕竟,你一般不会把写DB和清Cache捆绑成一个事务吧?

我们被类似的问题困扰了很久,尤其是涉及到一些商业的需求,数据的一致性非常重要。因此,我们基于Tungsten Replicator,开发了一个插件,能够将MySQL的数据更新,同步到队列中,由后端的逻辑实现进一步的数据同步操作。

队列,依然采用kestrel。它的高效,支持可靠获取以及子队列,非常适合这种需求。

附上系统架构图吧。。。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值