macOS、Linux CentOS 、Docker安装部署canal-server(canal-deployer)服务

1、环境准备

canal-server(canal-deployer)依赖jdk,需要先安装部署好jdk1.8

mysql开启binlog

2、安装部署

2.1、Docker方式安装部署

这里以1.1.6版本为例,其他版本选择:

Docker Hub

#拉取canal-server镜像
docker pull canal/canal-server:v1.1.6
 
#拉取完成后,先启动下canal-server,主要是为了从里面copy出配置文件
docker run --name canal-server -d canal/canal-server:v1.1.6
 
#新建canal-server目录用于存放相应配置文件和日志
mkdir -p ~/canal-server
 
#cp到指定刚刚新建的目录
docker cp canal-server:/home/admin/canal-server/conf/canal.properties ~/canal-server
docker cp canal-server:/home/admin/canal-server/conf/example/instance.properties ~/canal-server
 
#修改canal.properties和instance.properties相关配置
#具体需要修改的地方参考第3步
vim ~/canal-server/canal.properties
vim ~/canal-server/instance.properties
 
#修改完成后,将之前的canal-server容器关闭并删除,重新起一个容器
docker stop canal-server
docker rm canal-server
#启动新的容器,这里-v是将外部的文件挂载到容器内部 这样就不用每次启动都要配置参数了
docker run --name canal-server -p 11111:11111 -d \
-v ~/canal-server/instance.properties:/home/admin/canal-server/conf/example/instance.properties \
-v ~/canal-server/canal.properties:/home/admin/canal-server/conf/canal.properties \
-v ~/canal-server/logs/:/home/admin/canal-server/logs/ \
canal/canal-server:v1.1.6
 
#通过日志检查是否启动成功 两个日志都无报错表示启动成功了
tail -1000f ~/canal-server/logs/canal/canal.log
tail -1000f ~/canal-server/logs/example/example.log

#启动、停止
docker start canal-server
docker stop canal-server

2.2、压缩包方式安装部署

2.2.1、下载

下载并解压到指定目录,如/home/admin/

https://github.com/alibaba/canal/releases/download/canal-1.1.6/canal.deployer-1.1.6.tar.gz

tar -xvf canal.deployer-1.1.6.tar.gz

2.2.2、修改配置,具体需要修改的地方参考第3步

cd /home/admin/canal.deployer-1.1.6/conf

vim canal.properties

vim example/instance.properties

2.2.3、启动、重启、停止等

cd /home/admin/canal.deployer-1.1.6

sh bin/startup.sh

sh bin/restart.sh

sh bin/stop.sh

2.2.4、查看日志

/home/admin/canal.deployer-1.1.6/logs/canal/canal.log

/home/admin/canal.deployer-1.1.6/logs/example/example.log

3、需要修改的配置(只修改列出来的部分,其余不用动)

3.1、canal.properties

#这里以rocketMQ为例
canal.serverMode = rocketMQ
 
#关闭tsdb主要为了解决:表结构发生改变导致不增量同步问题
canal.instance.tsdb.enable = false
 
#如果使用的RocketMQ为阿里云商业mq时,需要指定以下两个配置
canal.aliyun.accessKey = accessKey
canal.aliyun.secretKey = secretKey
 
#RocketMQ相关配置
rocketmq.producer.group = test
rocketmq.enable.message.trace = false
rocketmq.customized.trace.topic =
rocketmq.namespace =
rocketmq.namesrv.addr = 127.0.0.1:9876
rocketmq.retry.times.when.send.failed = 0
rocketmq.vip.channel.enabled = false
rocketmq.tag =

3.2、instance.properties

#配置slaveId,不能和现有mysql从库的slaveId重复,默认为0
canal.instance.mysql.slaveId=1
 
#配置mysql连接
canal.instance.master.address=127.0.0.1:3306
canal.instance.dbUsername=root
canal.instance.dbPassword=123456
 
#需要同步的表
canal.instance.filter.regex=.*\\..*
 
#mq配置
#mq里的topic名
canal.mq.topic=example

canal.mq.partition=0
#分区数
canal.mq.partitionsNum=4
 
#库名.表名:唯一主键,多个表之间用逗号分隔
canal.mq.partitionHash=.*\\..*:$pk$

相关官方文档:

Canal Kafka RocketMQ QuickStart · alibaba/canal Wiki · GitHub

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

峰子哥哥

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值