最近业务开始需要实时抽取数据,中间权限需要沟通,为了不让自己给DBA添加麻烦,还是补补关于这方面的基础:
来源:http://blog.csdn.net/heiyeshuwu/article/details/8619338
先介绍下背景吧,方便理解:
早期,阿里巴巴B2B公司因为存在杭州和美国双机房部署,存在跨机房同步的业务需求。不过早期的数据库同步业务,主要是基于trigger的方式获取增量变更,不过从2010年开始,阿里系公司开始逐步的尝试基于数据库的日志解析,获取增量变更进行同步,由此衍生出了增量订阅&消费的业务。
名称:canal [k?‘næl]
译意: 水道/管道/沟渠
语言: 纯java开发
定位: 基于数据库增量日志解析,提供增量数据订阅&消费,目前主要支持了mysql
从上层来看,复制分成三步:
a:canal的原理是基于mysql binlog技术,所以一定要需要开启mysql的binlog写入功能,并且配置binlog模式为row.
b:canal的原理是模拟自己为mysql salave,所以这里一定需要做为mysql slave的相关权限。
原文:http://www.cnblogs.com/judylucky/p/4318798.html