8.每日一读—Canal实现mysql异构数据同步

8.每日一读—Canal实现mysql异构数据同步,第1张

8.每日一读—Canal实现mysql异构数据同步 1.什么是异构数据

MySQL中存储的数据,elasticsearch中存储的数据。这两种数据就是异构数据。

2.身处漩涡中心的mysql团队

举个栗子:
在一个商城的开发项目中有一个mysql团队,使用mysql来保存商品的信息。
现在需要增加一个“全文检索”的功能,成立了Elasticsearch团队。mysql中新增加一条信息,就需要mysql团队调用Elasticsearch团队的接口新建商品信息。
这样就出现了一个严重的问题,代码出现了强耦合。mysql团队必须了解elasticsearch团队提供的接口才能实现,但是这项工作并不mysql团队的工作范围!
现在又新增一个功能,需要成立MongoDB团队。那么mysql团队由必须了解MongoDB的接口。

思考:
如何做到数据自动同步,还要团队之间的解耦?

3.什么是Canal

Canal是阿里巴巴旗下的JAVA一款开源项目。基于数据库增量日志解析,提供增量数据订阅&消费,目前主要支持了MySQL

4.Canal的基本原理 4.1 mysql的主从复制

4.2 Canal 就是将从数据库改为Canal


通过Canal解决了数据监听的问题
下面要解决解耦的问题

4.使用MQ消息队列实现解耦

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/5705112.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-12-17
下一篇 2022-12-17

发表评论

登录后才能评论

评论列表(0条)

保存