`
liyonghui160com
  • 浏览: 777046 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

canal使用配置详解

阅读更多

 

 

a.  canal的原理是基于mysql binlog技术,所以这里一定需要开启mysql的binlog写入功能,并且配置binlog模式为row. 

 

[mysqld]  
log-bin=mysql-bin #添加这一行就ok  
binlog-format=ROW #选择row模式  
server_id=1 #配置mysql replaction需要定义,不能和canal的slaveId重复  
 

 

 

canal的原理是模拟自己为mysql slave,所以这里一定需要做为mysql slave的相关权限 

 

CREATE USER canal IDENTIFIED BY 'canal';    
GRANT SELECT, REPLICATION SLAVE, REPLICATION CLIENT ON *.* TO 'canal'@'%'  IDENTIFIED BY 'canal' WITH GRANT OPTION;
FLUSH PRIVILEGES; 
 

 

针对已有的账户可通过grants查询权限:

 

show grants for 'canal'
 

 

 

 

启动步骤:

 

1.  下载canal

 

下载部署包

 

    wget http://canal4mysql.googlecode.com/files/canal.deployer-1.0.0.tar.gz  

 

or 

 

自己编译 

 

    git clone git@github.com:otter-projects/canal.git  

    cd canal;   

    mvn clean install -Dmaven.test.skip -Denv=release  

 

    编译完成后,会在根目录下产生target/canal.deployer-$version.tar.gz 

 

 

2.  解压缩

 

    mkdir /tmp/canal  

    tar zxvf canal.deployer-1.0.0.tar.gz  -C /tmp/canal  

 

   解压完成后,进入/tmp/canal目录,可以看到如下结构:

 

    drwxr-xr-x 2 jianghang jianghang  136 2013-02-05 21:51 bin  

    drwxr-xr-x 4 jianghang jianghang  160 2013-02-05 21:51 conf  

    drwxr-xr-x 2 jianghang jianghang 1.3K 2013-02-05 21:51 lib  

    drwxr-xr-x 2 jianghang jianghang   48 2013-02-05 21:29 logs  

 

3.  配置修改

 

公用参数:   

 

    vi conf/canal.properties  

 

    #################################################  

    #########               common argument         #############   

    #################################################  

    canal.id= 1  

    canal.address=  

    canal.port= 11111  

    canal.zkServers=  

    # flush data to zk  

    canal.zookeeper.flush.period = 1000  

    ## memory store RingBuffer size, should be Math.pow(2,n)  

    canal.instance.memory.buffer.size = 32768  

      

    ## detecing config  

    canal.instance.detecting.enable = false  

    canal.instance.detecting.sql = insert into retl.xdual values(1,now()) on duplicate key update x=now()  

    canal.instance.detecting.interval.time = 3   

    canal.instance.detecting.retry.threshold = 3   

    canal.instance.detecting.heartbeatHaEnable = false  

      

    # support maximum transaction size, more than the size of the transaction will be cut into multiple transactions delivery  

    canal.instance.transactionn.size =  1024  

      

    # network config  

    canal.instance.network.receiveBufferSize = 16384  

    canal.instance.network.sendBufferSize = 16384  

    canal.instance.network.soTimeout = 30  

      

    #################################################  

    #########               destinations            #############   

    #################################################  

    canal.destinations= example  

      

    canal.instance.global.mode = spring   

    canal.instance.global.lazy = true  ##修改为false,代表立马启动  

    #canal.instance.global.manager.address = 127.0.0.1:1099  

    canal.instance.global.spring.xml = classpath:spring/memory-instance.xml  

    #canal.instance.global.spring.xml = classpath:spring/default-instance.xml  

 

 

应用参数:

 

    vi conf/example/instance.properties  

 

Instance.properties

 

    #################################################  

    ## mysql serverId  

    canal.instance.mysql.slaveId = 1234  

      

    # position info  

    canal.instance.master.address = 127.0.0.1:3306 #改成自己的数据库地址  

    canal.instance.master.journal.name =   

    canal.instance.master.position =   

    canal.instance.master.timestamp =   

      

    #canal.instance.standby.address =   

    #canal.instance.standby.journal.name =  

    #canal.instance.standby.position =   

    #canal.instance.standby.timestamp =   

      

    # username/password  

    canal.instance.dbUsername = retl  #改成自己的数据库信息  

    canal.instance.dbPassword = retl  #改成自己的数据库信息  

    canal.instance.defaultDatabaseName =   #改成自己的数据库信息  

    canal.instance.connectionCharsetNumber = 33  #改成自己的数据库信息  

    canal.instance.connectionCharset = UTF-8  #改成自己的数据库信息  

      

    # table regex  

    canal.instance.filter.regex = .*\\..*  

      

    ################################################# 

 

 

 说明:

 

    canal.instance.connectionCharset 代表数据库的编码方式对应到java中的编码类型,比如UTF-8,GBK , ISO-8859-1

    canal.instance.connectionCharsetNumber 代表数据库的编码方式对应mysql中的唯一id,详细的映射关系可查看:com.mysql.jdbc.CharsetMapping.INDEX_TO_CHARSET

    针对常见的编码:

    utf-8  <=>  33

    gb2312 <=> 24

    gbk <=> 28

 

4.   准备启动

 

    sh bin/startup.sh  

 

5.  查看日志

 

    vi logs/canal/canal.log  

 

    2013-02-05 22:45:27.967 [main] INFO  com.alibaba.otter.canal.deployer.CanalLauncher - ## start the canal server.  

    2013-02-05 22:45:28.113 [main] INFO  com.alibaba.otter.canal.deployer.CanalController - ## start the canal server[10.1.29.120:11111]  

    2013-02-05 22:45:28.210 [main] INFO  com.alibaba.otter.canal.deployer.CanalLauncher - ## the canal server is running now ......  

 

    具体instance的日志:

 

    vi logs/example/example.log  

 

    2013-02-05 22:50:45.636 [main] INFO  c.a.o.c.i.spring.support.PropertyPlaceholderConfigurer - Loading properties file from class path resource [canal.properties]  

    2013-02-05 22:50:45.641 [main] INFO  c.a.o.c.i.spring.support.PropertyPlaceholderConfigurer - Loading properties file from class path resource [example/instance.properties]  

    2013-02-05 22:50:45.803 [main] INFO  c.a.otter.canal.instance.spring.CanalInstanceWithSpring - start CannalInstance for 1-example   

    2013-02-05 22:50:45.810 [main] INFO  c.a.otter.canal.instance.spring.CanalInstanceWithSpring - start successful....  

 

6.  关闭

 

    sh bin/stop.sh  

 

 

使用中出现以下错误:Could not find first log file name in binary log index file

 

 

2015-01-15 10:40:01.756 [destination = example , address = /127.0.0.1:3306 , EventParser] ERROR com.alibaba.otter.canal.common.alarm.LogAlarmHandler - destination:example[java.io.IOException: Received error packet: errno = 1236, sqlstate = HY000 errmsg = Could not find first log file name in binary log index file
        at com.alibaba.otter.canal.parse.inbound.mysql.dbsync.DirectLogFetcher.fetch(DirectLogFetcher.java:95)
        at com.alibaba.otter.canal.parse.inbound.mysql.MysqlConnection.dump(MysqlConnection.java:116)
        at com.alibaba.otter.canal.parse.inbound.AbstractEventParser$3.run(AbstractEventParser.java:209)
        at java.lang.Thread.run(Thread.java:662)
 

 

 

最终解决因为没有权限,使用root用户运行成功!

 

分享到:
评论
2 楼 liyonghui160com 2017-11-29  
RAYFUXK 写道
您好,我最近也在使用Canal,但是遇到了一个问题。
ERROR com.alibaba.otter.canal.common.alarm.LogAlarmHandler - destination:example[com.alibaba.otter.canal.parse.exception.CanalParseException: java.io.IOException: connect /127.0.0.1:3306 failure:java.io.IOException: Error When doing Client Authentication:ErrorPacket [errorNumber=1045, fieldCount=-1, message=Access denied for user 'canal'@'localhost' (using password: YES), sqlState=28000, sqlStateMarker=#]
具体细节我发了issue,请问可以帮我看一下么???
https://github.com/alibaba/canal/issues/146


用户名密码 不对吧 要不就是没有权限
1 楼 RAYFUXK 2016-03-05  
您好,我最近也在使用Canal,但是遇到了一个问题。
ERROR com.alibaba.otter.canal.common.alarm.LogAlarmHandler - destination:example[com.alibaba.otter.canal.parse.exception.CanalParseException: java.io.IOException: connect /127.0.0.1:3306 failure:java.io.IOException: Error When doing Client Authentication:ErrorPacket [errorNumber=1045, fieldCount=-1, message=Access denied for user 'canal'@'localhost' (using password: YES), sqlState=28000, sqlStateMarker=#]
具体细节我发了issue,请问可以帮我看一下么???
https://github.com/alibaba/canal/issues/146

相关推荐

    阿里巴巴-canal使用配置说明-图灵杨过1

    这篇配置说明主要介绍了如何在Canal中配置MySQL实例进行数据同步。 首先,`canal.instance.mysql.slaveId`是MySQL的server ID,这个ID在每个从库上必须是唯一的。在Canal v1.0.26及更高版本中,这个值会自动生成,...

    mysql主从同步及canal配置详解.docx

    MySQL 主从同步及 Canal 配置详解 MySQL 主从同步是指将一个 MySQL 服务器的数据实时同步到另一个 MySQL 服务器上,以保证数据的一致性和高可用性。该技术主要基于 binlog 技术,下面将详细介绍 MySQL 主从同步的...

    canal.deployer-1.1.6

    《Canal Deployer 1.1.6:MySQL数据同步利器详解》 Canal Deployer是阿里巴巴开源的数据同步工具Canal的重要组成部分,主要用于部署和管理Canal实例。在1.1.6版本中,它提供了稳定高效的数据变更捕获与传输服务,...

    canal安装包免费下载.mysql同步ES工具

    Canal 在这里被当作一个软件或者数据库同步的插件来使用,它提供了简单易用的接口和配置,方便用户集成到自己的系统中,实现数据的实时迁移和备份。 5. **Windows 使用**: 虽然 Canal 常用于服务器环境,但描述...

    canal-1.1.5.zip

    《阿里巴巴开源项目Canal详解与应用》 Canal,由阿里巴巴开源的一款高性能、轻量级的MySQL数据库实时增量数据订阅和消费组件,主要...在Java开发中,熟练掌握Canal的使用和配置,能极大地提升数据处理的效率和灵活性。

    canal.deployer-1.1.5-SNAPSHOT.tar.gz

    《Canal工具详解:深入理解canal.deployer-1.1.5-SNAPSHOT.tar.gz》 在IT行业中,数据库的实时同步与监控是至关重要的任务,尤其在大数据处理、分布式系统以及微服务架构中。Canal是一款由阿里巴巴开源的数据库变更...

    canal.deployer-1.1.6.tar.gz

    《Canal Deployer 1.1.6:MySQL 数据库实时同步工具详解》 Canal Deployer 是阿里巴巴开源的一款高效、稳定、轻量级的 MySQL 数据库增量日志解析组件,其主要功能是实现 MySQL 数据库到其他系统(如 Elasticsearch...

    最新版 canal.deployer-1.1.4.tar.gz

    《Canal Deployer 1.1.4:MySQL数据同步利器详解》 在数据库管理领域,数据同步是一项至关重要的任务,特别是在分布式系统中,实时的数据复制和同步是保证多节点间数据一致性的基础。Canal是一款由阿里巴巴开源的、...

    starter-canal.zip

    本篇文章将详细讲解如何在SpringBoot工程中集成Canal,以及相关的配置和使用方法。 首先,让我们理解Canal的基本概念。Canal主要负责监听MySQL的数据变更事件,当数据库中的表发生INSERT、UPDATE、DELETE操作时,...

    canal-1.1.4.rar

    4. **配置详解**:Canal的配置文件包括canal.properties、meta.dat、instance.properties等,其中包含了服务器地址、数据库连接信息、过滤规则等重要设置。理解并正确配置这些参数是保证Canal正常运行的关键。 5. *...

    com.xpand.starter-canal.jar

    《Canal MySQL监听器资源包详解与数据同步实践》 在数据库管理中,实时的数据同步是一项重要的任务,尤其是在分布式系统中,确保多个数据库实例间的数据一致性至关重要。Canal,一个由阿里巴巴开源的、轻量级的数据...

    canal1.14.zip

    《Canal:阿里巴巴开源数据库增量同步工具详解》 在当今的信息化时代,数据已经成为企业的重要资产,而数据库作为数据的主要存储场所,其管理和同步尤为重要。阿里巴巴开源的Canal项目,便是一个专注于数据库增量...

    canal-canal-1.1.7.tar.gz

    《Canal:MySQL数据库同步利器详解》 Canal是一款由阿里巴巴开源的,专门针对MySQL数据库设计的数据变更(CDC,Change Data Capture)系统。在“canal-canal-1.1.7.tar.gz”这个压缩包中,包含了Canal的1.1.7版本的...

    canal.deployer-1.1.3.tar

    《MySQL数据库监控神器Canal Deployer 1.1.3详解》 在IT行业中,数据库监控是运维工作的重要环节,而Canal则是阿里巴巴开源的一款高效、稳定、强大的MySQL数据库增量日志订阅与消费组件。Canal Deployer是其部署...

    canal-master.zip

    《Canal主从同步详解与部署指南》 在IT领域,数据库主从同步是一个至关重要的技术环节,它确保了数据...在实际工作中,根据具体需求调整Canal配置和选择合适的数据同步策略,将是确保数据安全和业务连续性的重要手段。

    厂商实时需求canal与es安装文档

    - **启动canal服务**:分别在主备机上启动canal服务,使用`bin/startup.sh`脚本进行启动,并通过查看`logs/canal/canal.log`来确认服务启动状态。 ##### 3. Kafka配置 - **安装Kafka**:如果尚未安装Kafka,则需先...

    canal1.1.4(1.1.5).rar

    《Canal 1.1.4与1.1.5版本详解及组件解析》 Canal,由阿里巴巴开源,是一款高效、稳定、轻量级的数据库增量数据订阅和消费组件,广泛应用于数据同步、实时数据接入等场景。该压缩包包含Canal的1.1.4和1.1.5两个版本...

    canal.deployer-1.1.4.rar

    《Canal:MySQL到Kafka、ES、HBase的实时数据同步详解》 在大数据处理领域,数据同步是一项至关重要的任务。Canal是阿里巴巴开源的一个轻量级数据库变更数据捕获(CDC,Change Data Capture)工具,它能够实现实时...

    canal-rabbitmq-1.1.5封装包

    《Canal与RabbitMQ整合应用详解》 在分布式系统中,数据的实时同步和变更事件的处理是一项重要任务。Canal是阿里巴巴开源的一个数据库增量日志抽取框架,主要用于实现MySQL到其他系统的实时数据同步,比如数据仓库...

Global site tag (gtag.js) - Google Analytics