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即可
在这里插入图片描述

相关内容

热门资讯

【NI Multisim 14...   目录 序言 一、工具栏 🍊1.“标准”工具栏 🍊 2.视图工具...
银河麒麟V10SP1高级服务器... 银河麒麟高级服务器操作系统简介: 银河麒麟高级服务器操作系统V10是针对企业级关键业务...
不能访问光猫的的管理页面 光猫是现代家庭宽带网络的重要组成部分,它可以提供高速稳定的网络连接。但是,有时候我们会遇到不能访问光...
AWSECS:访问外部网络时出... 如果您在AWS ECS中部署了应用程序,并且该应用程序需要访问外部网络,但是无法正常访问,可能是因为...
Android|无法访问或保存... 这个问题可能是由于权限设置不正确导致的。您需要在应用程序清单文件中添加以下代码来请求适当的权限:此外...
北信源内网安全管理卸载 北信源内网安全管理是一款网络安全管理软件,主要用于保护内网安全。在日常使用过程中,卸载该软件是一种常...
AWSElasticBeans... 在Dockerfile中手动配置nginx反向代理。例如,在Dockerfile中添加以下代码:FR...
AsusVivobook无法开... 首先,我们可以尝试重置BIOS(Basic Input/Output System)来解决这个问题。...
ASM贪吃蛇游戏-解决错误的问... 要解决ASM贪吃蛇游戏中的错误问题,你可以按照以下步骤进行:首先,确定错误的具体表现和问题所在。在贪...
月入8000+的steam搬砖... 大家好,我是阿阳 今天要给大家介绍的是 steam 游戏搬砖项目,目前...