canal简单入门,mysql开启binlog

本文介绍了MySQL数据库开启binlog以及使用Canal进行数据同步的简单入门。首先解释了Canal的工作原理,它是基于MySQL的二进制日志事件进行增量数据订阅和消费。接着详细阐述了开启MySQL binlog的步骤,包括在Docker中部署MySQL并验证binlog状态。然后讲解了Canal服务器的部署,包括下载、配置和启动。最后提到了测试代码的参考链接。
摘要由CSDN通过智能技术生成


前言

开启mysql的binlog日志记录,配合canal实现简单的数据同步功能。


一、canal是什么?

canal [kə’næl],译意为水道/管道/沟渠,主要用途是基于 MySQL 数据库增量日志解析,提供增量数据订阅和消费

早期阿里巴巴因为杭州和美国双机房部署,存在跨机房同步的业务需求,实现方式主要是基于业务 trigger 获取增量变更。从 2010 年开始,业务逐步尝试数据库日志解析获取增量变更进行同步,由此衍生出了大量的数据库增量订阅和消费业务。

基于日志增量订阅和消费的业务包括

数据库镜像
数据库实时备份
索引构建和实时维护(拆分异构索引、倒排索引等)
业务 cache 刷新
带业务逻辑的增量数据处理
当前的 canal 支持源端 MySQL 版本包括 5.1.x , 5.5.x , 5.6.x , 5.7.x , 8.0.x

工作原理

MySQL主备复制原理

MySQL master 将数据变更写入二进制日志( binary log, 其中记录叫做二进制日志事件binary log events,可以通过 show binlog events 进行查看)
MySQL slave 将 master 的 binary log events 拷贝到它的中继日志(relay log)
MySQL slave 重放 relay log 中事件,将数据变更反映它自己的数据
canal 工作原理
canal 模拟 MySQL slave 的交互协议,伪装自己为 MySQL slave ,向 MySQL master 发送dump 协议
MySQL master 收到 dump 请求,开始推送 binary log 给 slave (即 canal )
canal 解析 binary log 对象(原始为 byte 流)

二、使用步骤

1.mysql开启binlog

我安装的mysql是5.7的版本,使用的docker部署的
(1)拉取mysql镜像

docker pull mysql:5.7

(2)创建容器

docker run -id -p 3306:3306 --name=mysql -v
/root/mysql/conf:/etc/mysql/conf.d -v /root/mysql/logs:/logs -v
/root/mysql/data:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=root mysql:5.7

(3)进入容器,开启binlog

docker exec -it ba3d1b375939 /bin/bash
编辑配置
vi /etc/mysql/mysql.conf.d/mysqld.cnf
(vi命令提示找不到的安装一下)
apt-get update
apt-get install vim  
在配置文件最后加上
log-bin=/var/lib/mysql/mysql-bin
server-id=123454  

(4)推出之后重启mysql

docker restart ba3d1b375939

(5)在数据库验证是否开启

show variables like 'log_bin'

在这里插入图片描述

2.部署canal服务器

下载地址: https://github.com/alibaba/canal/releases.
(1)我是在win10上部署的,下载解压
在这里插入图片描述
(2)在conf/example/编辑配置文件instance.properties
在这里插入图片描述

## mysql serverId , v1.0.26+ will autoGen
## v1.0.26版本后会自动生成slaveId,所以可以不用配置
# canal.instance.mysql.slaveId=0

# 数据库地址
canal.instance.master.address=127.0.0.1:3306
# binlog日志名称
canal.instance.master.journal.name=
# mysql主库链接时起始的binlog偏移量
canal.instance.master.position=154
# mysql主库链接时起始的binlog的时间戳
canal.instance.master.timestamp=
canal.instance.master.gtid=

# username/password
# 在MySQL服务器授权的账号密码
canal.instance.dbUsername=root
canal.instance.dbPassword=root
# 字符集
canal.instance.connectionCharset = UTF-8
# enable druid Decrypt database password
canal.instance.enableDruid=false

# table regex .*\\..*表示监听所有表 也可以写具体的表名,用,隔开
canal.instance.filter.regex=.*\\..*
# mysql 数据解析表的黑名单,多个表用,隔开
canal.instance.filter.black.regex=

(3)保存后启动服务器
在这里插入图片描述
启动成功
在这里插入图片描述

3.测试代码

参考:https://blog.csdn.net/qq_43791139/article/details/107752629.

<dependency>
    <groupId>com.alibaba.otter</groupId>
    <artifactId>canal.client</artifactId>
    <version>1.1.0</version>
</dependency>
package com.demo.es.handler;

import com.alibaba.otter.canal.client.CanalConnector;
import com.alibaba.otter.canal.client.CanalConnectors;
import com.alibaba.otter.canal.protocol.CanalEntry.*;
import com.alibaba.otter.canal.protocol.Message;
import com.google.protobuf.InvalidProtocolBufferException;
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值