springboot整合canal实现与mysql数据实时同步

以下有关linux操作都是基于docker容器的

一、Canal介绍

1、介绍

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

2、Canal环境搭建

canal的原理是基于mysql binlog技术,所以这里一定需要开启mysql的binlog写入功能
(1)检查binlog功能是否有开启

mysql> show variables like ‘log_bin’;
±--------------±------+
| Variable_name | Value |
±--------------±------+
| log_bin | OFF |
±--------------±------+
1 row in set (0.00 sec)

(2)如果显示状态为OFF表示该功能未开启,开启binlog功能(mysql:5.7可能没有my.cnf文件,mysql:8.0有,没有的话自己新建,其他版本没试过)

1,修改 mysql 的配置文件 my.cnf
vi /etc/mysql/my.cnf
追加内容:
log-bin=mysql-bin #binlog文件名
binlog_format=ROW #选择row模式
server_id=1 #mysql实例id,不能和canal的slaveId重复
2,重启 mysql:
docker restart xxx
3,登录 mysql 客户端,查看 log_bin 变量
mysql> show variables like ‘log_bin’;
±--------------±------+
| Variable_name | Value |
±--------------±------+
| log_bin | ON|
±--------------±------+
1 row in set (0.00 sec)
————————————————
如果显示状态为ON表示该功能已开启

(3)在本地的mysql里面添加以下的相关用户和权限

CREATE USER ‘canal’@’%’ IDENTIFIED BY ‘canal’;
GRANT SHOW VIEW, SELECT, REPLICATION SLAVE, REPLICATION CLIENT ON . TO ‘canal’@’%’;
FLUSH PRIVILEGES;

3、下载安装Canal服务

(1)拉取镜像,不加版本号,默认为latest

docker pull canal/canal-server

(2)查看镜像是否拉去成功

docker images

在这里插入图片描述
(3)拉取成功后启动canal,从里面copy出配置文件

#启动镜像 
docker run --name canal -d canal/canal-server

#进入容器 查看配置文件路径
docker exec -it canal bash

#找到文件位置后 exit退出容器 将容器内部文件copy到外部
docker cp canal:/home/admin/canal-server/conf/canal.properties /home/canal/canal.properties
docker cp canal:/home/admin/canal-server/conf/example/instance.properties /home/canal/instance.properties

(4)文件cv后,修改instance.properties文件(address写的是服务器的ip)在这里插入图片描述

第一个红框改成你要监听数据库的地址和端口;第二个红框是你数据库的用户和密码,这个用户信息一定是要有全部权限的用户,非root用户,我在上面创建了canal用户;第三个是匹配数据表的规则,这里默认为全部表

(4)修改保存后,删除容器重新启动,挂载数据卷就可以避免每次启动又要配置参数了

#关闭容器
docker stop canal

#移除容器
docker rm canal

#启动容器,-v为挂载数据卷
 docker run --name canal -p 11111:11111 -d -v /home/xyouzi/canal/instance.properties:/home/admin/canal-server/conf/example/instance.properties -v /home/xyouzi/canal/canal.properties:/home/admin/canal-server/conf/canal.properties canal

二、创建canal_client模块(springboot整合使用)

引入相关依赖
<dependencies>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-web</artifactId>
    </dependency>

    <!--mysql-->
    <dependency>
        <groupId>mysql</groupId>
        <artifactId>mysql-connector-java</artifactId>
    </dependency>

    <dependency>
        <groupId>commons-dbutils</groupId>
        <artifactId>commons-dbutils</artifactId>
    </dependency>

    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-jdbc</artifactId>
    </dependency>

    <dependency>
        <groupId>com.alibaba.otter</groupId>
        <artifactId>canal.client</artifactId>
    </dependency>
</dependencies>
创建application.properties配置文件
# 服务端口
server.port=10000
# 服务名
spring.application.name=canal-client

# 环境设置:dev、test、prod
spring.profiles.active=dev

# mysql数据库连接
spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver
spring.datasource.url=jdbc:mysql://localhost:3306/guli?serverTimezone=GMT%2B8
spring.datasource.username=root
spring.datasource.password=root
编写canal客户端类
import com.alibaba.otter.canal.client.CanalConnector;
import com.alibaba.otter.canal.client.CanalConnectors;
import com.alibaba.otter.canal.protocol.CanalEntry.*
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值