开源中国

我们不支持 IE 10 及以下版本浏览器

It appears you’re using an unsupported browser

为了获得更好的浏览体验,我们强烈建议您使用较新版本的 Chrome、 Firefox、 Safari 等,或者升级到最新版本的IE浏览器。 如果您使用的是 IE 11 或以上版本,请关闭“兼容性视图”。
canal首页、文档和下载 - Binlog 的增量订阅和消费组件 - 开源中国社区
全部项目分类
Apache
Java 查看源码»
跨平台
阿里巴巴
jianghang115
分享
收藏
161 人收藏
收录时间:2013-02-22
canal 详细介绍

canal 是阿里巴巴 MySQL 数据库 Binlog 的增量订阅&消费组件。

名称:canal [kə'næl]
译意: 水道/管道/沟渠
语言: 纯java开发
定位: 基于数据库增量日志解析,提供增量数据订阅&消费,目前主要支持了MySQL

早期,阿里巴巴 B2B 公司因为存在杭州和美国双机房部署,存在跨机房同步的业务需求。不过早期的数据库同步业务,主要是基于 trigger 的方式获取增量 变更,不过从 2010 年开始,阿里系公司开始逐步的尝试基于数据库的日志解析,获取增量变更进行同步,由此衍生出了增量订阅&消费的业务,从此开 启了一段新纪元。ps. 目前内部使用的同步,已经支持 MySQL 5.x 和 Oracle 部分版本的日志解析

 

基于日志增量订阅&消费支持的业务:

  1. 数据库镜像

  2. 数据库实时备份

  3. 多级索引 (卖家和买家各自分库索引)

  4. search build

  5. 业务cache刷新

  6. 价格变化等重要业务消息

Canal 工作原理:

原理相对比较简单:

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

  2. mysql master收到dump请求,开始推送binary log给slave(也就是canal)

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

canal

选择将代码托管在码云
你还在等什么

可能是中国最大最好的代码托管平台


大家对 canal 的评论 (全部 5 条评论)
{{repayCom.userName}}
izhuanyer
我才不告诉你我有阿里云优惠卷->http://izhuanyer.top
小白小霸王
不错, 我们在用 .
超人star
给力!
老范的自留地
我们正在用 #canal#
OSC_代码审查官
#canal# 有人在用吗?
canal 相关博客
尚浩宇
canal安装
随笔,备忘
顶部