Canal工作原理

canal的工作原理类似mysql主从同步原理

先看下mysql主从同步的原理:

 

分成三步:

1、master将变更同步到二进制日志(binary log)文件中(这些记录叫做二进制日志事件,binary log events,可以通过show binlog events进行查看);

2、slave将master的binary log events拷贝到它的中继日志(relay log);

3、slave解析中继日志中的事件,解析成自己本身的数据。

 

canal工作原理:

1、canal模拟MySQL slave的交互协议,伪装自己为MySQL slave,向MySQL master发送dump协议

2、MySQL master收到dump协议请求,开始推送binary log 给canal

3、canal解析binary log对象(原始为byte流)

 

架构:

 

上图说明:

server:一个canal运行实例,对应一个jvm

实例对应一个数据队列(1个server对应1-n个实例)

instance模块:

  • EventParser:数据源接入,协议解析,模拟slave协议和master进行交互
  • EventSink:Paser和Store连接器,进行数据过滤,加工,分发
  • EventStore:数据存储
  • metaManager:增量订阅&消费信息管理器

 

 

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值