mysql canal cdc_数据增量收集CDC系统应用场景分析以及Canal应用步骤

很多应用场景下,除了收集数据库全量数据外,还希望只获取增量数据。例如,MySQL某个表从某个时刻开始修改、插入或者删除的数据。在这种情况下,CDC(Change

Data Capture)系统应运而生。本文将详情数据增量收集CDC系统应用场景分析以及Canal应用步骤。

CDC系统主要功能是捕获数据库中的数据升级,将增量数据发送给各个订阅者和消费者。CDC系统应用非常广泛,具体应用场景可形容为如下图所示:

39ec701c13311cf16ffb351a1e70b7d7.pngCDC应用场景

应用场景主要包括:

(1)异地机房同步。实现数据异地机房容灾。

(2)数据库实时备份。相似于master/slave架构,实时对数据库进行备份。

(3)业务Cache刷新。升级数据库成功的同时,刷新Cache的值。

(4)数据全库迁移。创立任务对列表,逐渐完成全库所有表的迁移。

CDC系统开源实现的典型系统是Canal。Canal的主要定位是基于数据库增量日志解析,提供增量数据订阅和消费,目前主要支持了MySQL关系数据库。

Canal的主要原理是,模拟数据库的主备复制协议,接收主数据库产生的binary log,进而捕获升级数据,以MySQL为例说明,具体步骤如下:

步骤1:Canal实现MySQL主备复制协议,向MySQL Server发送dump协议。

步骤2:MySQL收到dump请求,开始推送binlog给Canal。

步骤3:Canal解析binlog对象,并发送给各个消费者。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值