由于同步是基于binlog实现的,所以要先在mysql中开启binlog
修改my.cnf配置信息
server-id = 1
log-bin=mysql-bin # 开启 binlog
binlog-format=ROW # 选择 ROW 模式
重启mysql服务,然后连接到mysql服务,使用指令查看是否已经开启
show variables like '%log_bin%';
源数据库创建一个canal账号,并且设置slave,dump权限
CREATE USER canal IDENTIFIED BY 'canal';
GRANT SELECT, REPLICATION SLAVE, REPLICATION CLIENT ON *.* TO 'canal'@'%';
-- GRANT ALL PRIVILEGES ON *.* TO 'canal'@'%' ;
FLUSH PRIVILEGES;
因为mysql8.0.3后身份检验方式为caching_sha2_password,但canal使用的是mysql_native_password,因此需要设置检验方式(如果该版本之前的可跳过),否则会报错IOException: caching_sha2_password Auth failed
ALTER USER 'canal'@'%' IDENTIFIED WITH mysql_native_password BY 'canal';
select host,user,plugin from mysql.user ;
docker pull canal/canal-server:latest
docker run -p 11111:11111 --name canal -d canal/canal-server:latest
初次启动后如果我们需要修改instance.properties,建议复制到宿主机进行修改
docker cp canal:/home/admin/canal-server/conf/example/instance.properties /home/ninesun/mydata/canal/conf/
PS:/home/ninesun/mydata/canal/conf/是我宿主机的目录,自己选择自己的复制地址
具体需要修改的内容大致如下图所示,自己按照需求修改
instance.properties配置描述
同时我们还需要设置全量同步
查询源mysql服务器的binlog位置
# 源mysql服务器中登陆mysql执行
show binary logs;
然后将你修改好的配置文件复制回容器内
docker cp /home/ninesun/mydata/canal/conf/instance.properties canal:/home/admin/canal-server/conf/example/instance.properties
重启镜像即可
docker restart canal
docker exec -it canal bash
cd ./canal-server/logs/example/
cat ./example.log
若出现以下内容则表示配置成功
至此docker安装canal就结束了
下载地址:https://github.com/alibaba/canal/releases
同时Canal是基于Java开发的,所以要保证你的电脑上有jdk或jre
创建一个canal_manager数据库,编码格式utf8mb4(如果未安装admin管理服务则不需要该数据库),该数据库用于远程统一配置管理
导入脚本canal_manager.sql,初始化数据库结构数据,该脚本文件在canal.admin下的conf目录中
查询源mysql服务器的binlog位置
# 源mysql服务器中登陆mysql执行
show binary logs;
修改example/instance.properties
具体修改内容和我们docker里配置的一样
双击startup.sh即可