Canal安装教程
创始人
2024-06-02 07:15:45
0

文章目录

  • 1.开启Mysql的同步模式
  • 2.docker环境下安装Canal
    • 2.1 下载镜像
    • 2.2 启动镜像
    • 2.3 查看是否配置成功
  • 2.Windows环境下安装Canal
    • 2.1 管理端Admin操作
    • 2.2 配置修改
    • 2.3 启动

本文将详细介绍Canal在docker环境和windows环境下的安装教程

由于同步是基于binlog实现的,所以要先在mysql中开启binlog

1.开启Mysql的同步模式

修改my.cnf配置信息

server-id = 1
log-bin=mysql-bin # 开启 binlog
binlog-format=ROW # 选择 ROW 模式
  • docker环境下:/etc/mysql/my.cnf
  • windows环境下:my.ini
    在这里插入图片描述

重启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 ;

在这里插入图片描述

2.docker环境下安装Canal

2.1 下载镜像

docker pull canal/canal-server:latest

在这里插入图片描述

2.2 启动镜像

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

2.3 查看是否配置成功

  • 1.进入canal容器内
docker exec -it canal bash
cd  ./canal-server/logs/example/
cat ./example.log

在这里插入图片描述
若出现以下内容则表示配置成功
在这里插入图片描述

至此docker安装canal就结束了

2.Windows环境下安装Canal

下载地址:https://github.com/alibaba/canal/releases
在这里插入图片描述

同时Canal是基于Java开发的,所以要保证你的电脑上有jdk或jre

2.1 管理端Admin操作

创建一个canal_manager数据库,编码格式utf8mb4(如果未安装admin管理服务则不需要该数据库),该数据库用于远程统一配置管理
在这里插入图片描述

导入脚本canal_manager.sql,初始化数据库结构数据,该脚本文件在canal.admin下的conf目录中
在这里插入图片描述

2.2 配置修改

查询源mysql服务器的binlog位置

# 源mysql服务器中登陆mysql执行
show binary logs;

在这里插入图片描述

修改example/instance.properties
在这里插入图片描述

具体修改内容和我们docker里配置的一样
在这里插入图片描述

2.3 启动

双击startup.sh即可
在这里插入图片描述

相关内容

热门资讯

AWSECS:访问外部网络时出... 如果您在AWS ECS中部署了应用程序,并且该应用程序需要访问外部网络,但是无法正常访问,可能是因为...
AWSElasticBeans... 在Dockerfile中手动配置nginx反向代理。例如,在Dockerfile中添加以下代码:FR...
AWR报告解读 WORKLOAD REPOSITORY PDB report (PDB snapshots) AW...
AWS管理控制台菜单和权限 要在AWS管理控制台中创建菜单和权限,您可以使用AWS Identity and Access Ma...
北信源内网安全管理卸载 北信源内网安全管理是一款网络安全管理软件,主要用于保护内网安全。在日常使用过程中,卸载该软件是一种常...
​ToDesk 远程工具安装及... 目录 前言 ToDesk 优势 ToDesk 下载安装 ToDesk 功能展示 文件传输 设备链接 ...
Azure构建流程(Power... 这可能是由于配置错误导致的问题。请检查构建流程任务中的“发布构建制品”步骤,确保正确配置了“Arti...
群晖外网访问终极解决方法:IP... 写在前面的话 受够了群晖的quickconnet的小水管了,急需一个新的解决方法&#x...
AWSECS:哪种网络模式具有... 使用AWS ECS中的awsvpc网络模式来获得最佳性能。awsvpc网络模式允许ECS任务直接在V...
不能访问光猫的的管理页面 光猫是现代家庭宽带网络的重要组成部分,它可以提供高速稳定的网络连接。但是,有时候我们会遇到不能访问光...