【Docker】Docker下安装Canal并整合SpringBoot

InterviewCoder

# Canal 是一个同步增量数据的一个工具

# 目录

# 概念

canal 是阿里巴巴旗下的一款开源项目,纯 Java 开发。基于数据库增量日志解析,提供增量数据订阅 & 消费,目前主要支持了 MySQL(也支持 mariaDB)

# Mysql 开启 binlog

在部署 Canal 之前,需要先安装 Mysql。

我用的是 5.7.27 的 mysql

# 是否开启 binlog

输入以下命令,查看是否开启 binlog
OFF 则表示未开启 binlog

1
show variables like 'log_bin';

在这里插入图片描述

# 开启 binlog 日志

修改 mysql 的配置文件,在 [mysqld] 下添加以下内容

1
2
3
4
5
6
# server_id不重复即可,不要和canal的slaveId重复
server_id=1
# 开启binlog
log_bin = mysql-bin
# 选择row模式
binlog_format = ROW

修改完毕,重启 mysql
查看是否开启
在这里插入图片描述

# 创建授权用户

创建授权用户 canal 用于 cannal 服务监听 mysql 的 binlog

1
2
3
4
5
6
# 新建用户 用户名:canal  密码:canal 
CREATE USER canal IDENTIFIED by 'canal';
# 授权
GRANT SELECT, REPLICATION SLAVE, REPLICATION CLIENT ON *.* TO 'canal'@'%';
# 刷新MySQL的系统权限相关表
FLUSH PRIVILEGES;

# 部署 Canal

如果没有部署过 docker,看我之前写的 Linux 部署 Docker

# 拉取镜像

1
docker pull canal/canal-server:latest

# 挂载 properties 配置文件

先进行第一次运行,拷贝 properties 配置文件

1
docker run -p 11111:11111 --name canal -d canal/canal-server:latest

拷贝运行后的容器中配置文件,用来文件挂载

1
2
3
4
5
6
# 创建canal宿主机挂载目录
mkdir -p /opt/canal/conf
# 查看docker运行情况,复制容器id
docker ps
# 拷贝配置文件
docker cp 容器id:/home/admin/canal-server/conf/example/instance.properties /opt/canal/conf/

移除当前容器

1
2
docker stop canal
docker rm canal

修改配置文件
在这里插入图片描述

# 创建容器

运行新的容器,同时挂载修改后的配置文件

1
docker run -p 11111:11111 --name canal -v /opt/canal/conf/instance.properties:/home/admin/canal-server/conf/example/instance.properties -d canal/canal-server:latest

开放端口

1
firewall-cmd --zone=public --add-port=11111/tcp --permanent && firewall-cmd --reload

# 关于我

Brath 是一个热爱技术的 Java 程序猿,公众号「InterviewCoder」定期分享有趣有料的精品原创文章!

InterviewCoder

非常感谢各位人才能看到这里,原创不易,文章如果有帮助可以关注、点赞、分享或评论,这都是对我的莫大支持!

评论