1 什么是 Canal

阿里巴巴 B2B 公司,因为业务的特性,卖家主要集中在国内,买家主要集中在国外,所以衍生出了同步杭州和美国异地机房的需求,从 2010 年开始,阿里系公司开始逐步的尝试基于数据库的日志解析,获取增量变更进行同步,由此衍生出了增量订阅&消费的业务。

Canal 是用 Java 开发的基于数据库增量日志解析,提供增量数据订阅&消费的中间件。目前。Canal 主要支持了 MySQL 的 Binlog 解析,解析完成后才利用 Canal Client 来处理获得的相关数据。(数据库同步需要阿里的 Otter 中间件,基于 Canal)。

2 MySQL的Binlog

2.1 什么是 Binlog

MySQL 的二进制日志可以说 MySQL 最重要的日志了,它记录了所有的 DDL 和 DML(除了数据查询语句)语句,以事件形式记录,还包含语句所执行的消耗的时间,MySQL 的二进制日志是事务安全型的。

一般来说开启二进制日志大概会有 1%的性能损耗。二进制有两个最重要的使用场景:

其一:MySQL Replication在Master端开启Binlog,Master把它的二进制日志传递给Slaves来达到 Master-Slave 数据一致的目的。

其二:自然就是数据恢复了,通过使用 MySQL Binlog 工具来使恢复数据。

二进制日志包括两类文件:二进制日志索引文件(文件名后缀为.index)用于记录所有的二进制文件,二进制日志文件(文件名后缀为.00000*)记录数据库所有的 DDL 和 DML(除了数据查询语句)语句事件。

2.2 Binlog 的分类

MySQL Binlog 的格式有三种,分别是 STATEMENT,MIXED,ROW。在配置文件中可以选择配置 binlog_format= statement|mixed|row。三种格式的区别:

(1)statement:语句级,binlog 会记录每次一执行写操作的语句。相对 row 模式节省空间,但是可能产生不一致性,比如“update tt set create_date=now()”,如果用 binlog 日志进行恢复,由于执行时间不同可能产生的数据就不同。

优点:节省空间。

缺点:有可能造成数据不一致。

(2)row:行级, binlog 会记录每次操作后每行记录的变化。

优点:保持数据的绝对一致性。因为不管 sql 是什么,引用了什么函数,他只记录执行后的效果。

缺点:占用较大空间。

(3)mixed:statement的升级版,一定程度上解决了,因为一些情况而造成的statement模式不一致问题,默认还是statement,在某些情况下譬如:当函数中包含UUID()时;包含AUTO_INCREMENT 字段的表被更新时;执行 INSERT DELAYED 语句时;用 UDF 时;会按照ROW 的方式进行处理

优点:节省空间,同时兼顾了一定的一致性。

缺点:还有些极个别情况依旧会造成不一致,另外 statement 和 mixed 对于需要对binlog 的监控的情况都不方便。

综合上面对比,Canal 想做监控分析,选择 row 格式比较合适。

3 Canal 的工作原理

3.1 MySQL 主从复制过程

(1)Master 主库将改变记录,写到二进制日志(Binary Log)中;

(2)Slave 从库向 MySQL Master 发送 dump 协议,将 Master 主库的 binary log events 拷贝到它的中继日志(relay log);

(3)Slave 从库读取并重做中继日志中的事件,将改变的数据同步到自己的数据库。

3.2 Canal 的工作原理

很简单,就是把自己伪装成 Slave,假装从 Master 复制数据。

4 使用场景

(1)原始场景: 阿里 Otter 中间件的一部分

Otter 是阿里用于进行异地数据库之间的同步框架,Canal 是其中一部分。

(2)常见场景 1:更新缓存

(3)常见场景 2:抓取业务表的新增变化数据,用于制作实时统计(我们就是这种场景)

Canal(1):Canal入门相关推荐

  1. canal下载 linux_Canal入门

    配置mysql 1.mysql开启binlog mysql默认没有开启binlog,修改mysql的my.cnf文件,添加如下配置,注意binlog-format必须为row,因为binlog如果为S ...

  2. 「从零单排canal 01」 canal 10分钟入门(基于1.1.4版本)

    1.简介 canal [kə'næl],译意为水道/管道/沟渠,主要用途是基于 MySQL 数据库增量日志解析,提供增量数据 订阅 和 消费.应该是阿里云DTS(Data Transfer Servi ...

  3. mysql数据实时同步:Canal安装部署、kafka安装、zk安装、mysql安装、Canal Server+Canal Client HA,Canal+mysql+Kafka,相关验证(学习笔记)

    目录 Canal安装部署 1.1. 服务器准备 1.2. 设置主机名并配置hosts 1.3. 免密设置 1.4. 设置ntp时间 1.5. 关闭防火墙 1.6. 关闭selinux 1.7. 安装J ...

  4. Canal:部署Canal与Canal Admin

    简介 以下关于Canal的介绍来自Github官方介绍. canal [kə'næl],译意为水道/管道/沟渠,主要用途是基于MySQL数据库增量日志解析,提供增量数据订阅和消费. 工作原理 cana ...

  5. Canal 及canal.admin(v1.1.5)踩坑记录

    网址:GitHub - alibaba/canal: 阿里巴巴 MySQL binlog 增量订阅&消费组件 前期软件准备 上面的软件包(canal.deployer-1.1.5.tar.gz ...

  6. 【Canal】canal部署

    canal部署 1.修改master节点mysql的配置文件开启Binlog [mysqld] skip-ssl skip-host-cache skip-name-resolve default-t ...

  7. canal的java客户端_GitHub - cjl1001/canal-client: spring boot canal starter 易用的canal 客户端 canal client...

    易用的canal 客户端 easy canal client 介绍 canal 是阿里巴巴mysql数据库binlog的增量订阅&消费组件 使用该客户端前请先了解canal,https://g ...

  8. 【Canal】canal简介

    1.canal简介 canal是一个增量解析MySQL binlog日志解析,提供增量数据订阅和消费的组件. 官方github https://github.com/alibaba/canal 2.c ...

  9. canal deployer+canal adapter自动同步MySQL数据到ElasticSearch

    一.安装Elastic Search 6.8 1.下载 Elastic Search 6.8资源下载 2.部署环境配置 创建用户(es不能使用root启动,否则报错) adduser elastic ...

  10. Canal~1:canal原理

    canal原理 1 什么是 canal 2 使用场景 3 canal 的工作原理 4 MySQL 的 binlog (1) 什么是 binlog (2) binlog 的开启 (3) binlog 的 ...

最新文章

  1. 【JS】JS中数值型字符串相加变成拼接字符串的解决方法
  2. jQuery选择器全集详解
  3. plSQL复制数据的方法
  4. 不要迷失在技术的海洋中【转】
  5. 计算机态,(计算机)有限态自动机,FSM(finite state machine),音标,读音,翻译,英文例句,英语词典...
  6. duilib vs2015 安装_FFmpeg视频播放器开发-FFmpeg简介与项目环境搭建(一)
  7. java线程初始方法三种_Java 多线程 三种实现方式
  8. SLAM GMapping(8)重采样
  9. vsco使用教程_这可能不是一篇你期望的教程--VSCO
  10. android xml 焦点,android TV 焦点选中放大效果
  11. (二)javascript中int和string转换
  12. html select 样式t调整_用纯css改变下拉列表select框的默认样式
  13. python定义空函数体_Python 2.2 定义函数
  14. SQL文件示例(Mysql)
  15. 74LS系列芯片简记——00-09
  16. 如何免费将网页内容转成Word文档
  17. 云服务器安装不了声卡,驱动精灵怎么安装声卡 声卡驱动安装方法
  18. HDU-4747 二分+线段树
  19. 广东英语高考怎么计算机,如何应对广东高考英语听说考试
  20. Android马甲包

热门文章

  1. Hive SQL之FULL JOIN优化
  2. Python之画蟒蛇
  3. 目前工作中的一些问题
  4. 世界上最遥远的距离(张小娴)
  5. 计算机支架式教学案例,支架式教学策略及案例分析
  6. Vue中v-if的妙用,v-show无法替代
  7. STM32之TIM 舵机控制PWM
  8. Java中静态变量与静态方法的继承
  9. 计算机组成原理补码加法证明,补码加减法运算(计算机组成原理).ppt
  10. H5C3基础学习总结之(毛玻璃)滤镜及动画过渡