46.canal 架构以及安装

2.3.1 canal 架构

 2.3.2 canal 的下载和安装

https://github.com/alibaba/canal/releases

我们直接/2.资料/02-工具下的 canal.deployer-1.1.4.tar.gz 拷贝到 /opt/sortware 目录
下,然后解压到 /opt/module/canal 包下
注意: canal 解压后是散的,我们在指定解压目录的时候需要将 canal 指定上

 

2.4 canal 单机版
2.4.1 修改 conf/canal.properties 的配置

 

这个文件是 canal 的基本通用配置,canal 端口号默认就是 11111
修改 canal 的输出 model,默认 tcp,改为输出到 kafka

 

tcp 就是输出到 canal 客户端,通过编写 Java 代码处理
修改 Kafka 集群的地址

 

如果创建多个实例
通过前面 canal 架构,我们可以知道,一个 canal 服务中可以有多个 instance,conf/
下的每一个 example 即是一个实例,每个实例下面都有独立的配置文件。默认只有一个实
例 example,如果需要多个实例处理不同的 MySQL 数据的话,直接拷贝出多个 example,
并对其重新命名,命名和配置文件中指定的名称一致,然后修改 canal.properties 中的
canal.destinations=实例 1,实例 2,实例 3。
2.4.2 修改 instance.properties
我们这里只读取一个 MySQL 数据,所以只有一个实例,这个实例的配置文件在
conf/example 目录下

 

配置 MySQL 服务器地址

 

配置连接 MySQL 的用户名和密码,默认就是我们前面授权的 canal

修改输出到 Kafka 的主题以及分区数

 

注意:默认还是输出到指定 Kafka 主题的一个 kafka 分区,因为多个分区并行可能会打乱
binlog 的顺序
如果要提高并行度,首先设置 kafka 的分区数>1,然后设置 canal.mq.partitionHash 属性

 

2.4.3 单机 canal 测试

 

 启动 Kafka 消费客户端测试,查看消费情况

 运行/opt/module/rt_dblog 中生成模拟数据

 2.5 canal 高可用(了解)

这种 zookeeper 为观察者监控的模式, 只能实现高可用,而不是负载均衡 ,即同一时点只
有一个 canal-server 节点能够监控某个数据源,只要这个节点能够正常工作,那么其他监控这
个数据源的 canal-server 只能做 stand-by ,直到工作节点停掉,其他 canal-server 节点才
能抢占。因为有一个 stand-by 也要占用资源,同时 canal 传输数据宕机的情况也比较少,所
以好多企业是不配置 canal 的高可用的。
2.5.1 停止单机 canal 进程

 

2.5.2 在 hadoop202 上修改 canal.properties
配置 zookeeper

 

避免发送重复数据(否则在切换 active 的时候会重复发送数据)

 2.5.3 把 canal 目录分发给其他虚拟机

[atguigu@hadoop202 module]$ xsync canal/

2.5.4 测试
先在 hadoop202 启动 canal,再在 hadoop203 上启动 canal
[atguigu@hadoop202 canal]$ bin/startup.sh
启动 kafka 消费客户端
[atguigu@hadoop202 kafka]$ bin/kafka-console-consumer.sh --bootstrap-server
hadoop202:9092 --topic gmall2020_db_c
在数据库 gmall2020 随便一张表中修改一条数据,查看效果
挂掉 202 再次修改数据,查看效果
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

大数据开发工程师-宋权

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值