docker安装canal1.1.5监控mysql的binlog日志并配置rocketmq进行数据同步到elasticsearch(超级大干货)

这篇具有很好参考价值的文章主要介绍了docker安装canal1.1.5监控mysql的binlog日志并配置rocketmq进行数据同步到elasticsearch(超级大干货)。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

直接来,不逼逼(canal官网说的很明白,伪从节点请求dump。。。然后这个那个的,自行查阅资料)

1、直接拉取canal镜像

docker pull canal/canal-server:v1.1.5

2、创建canal文件夹,用来存在容器挂载到宿主机的目录或文件(注:本实例在/home下操作)

mkdir canal && cd $_ && mkdir conf

3、先启动canal容器,把需要挂载的目录都copy出来,本例子只挂载了conf和logs目录(自己还想挂载啥东西就进去容器里面看看呗,docker exec -it canal /bin/bash)

// 启动一个临时容器
docker run --name=canal -p 11111:11111 -d canal/canal-server:v1.1.5
// copy容器内部目录到指定目录中(本实例在/home/canal下操作,注意修改)
docker cp canal:/home/admin/canal-server/conf/canal.properties /home/canal/conf/
docker cp canal:/home/admin/canal-server/conf/example/instance.properties /home/canal/conf/
docker cp canal:/home/admin/canal-server/logs /home/canal/logs

  4、第三步完事后直接把临时的canal容器删除了呗(先停,再删)

docker stop canal
docker rm canal

 5、开启启动一个正式的容器咯(-v:挂载的目录需要注意修改)

docker run --name=canal -p 11111:11111 -v /home/canal/conf/canal.properties:/home/admin/canal-server/conf/canal.properties -v /home/canal/conf/instance.properties:/home/admin/canal-server/conf/example/instance.properties -v /home/canal/logs:/home/admin/canal-server/logs -id canal/canal-server:v1.1.5

6、第五步完成后意义不大,我们要开始配置我们需要监听的mysql的binlog啦,监听前需要对我们的mysql有几个前提条件,需要开启binlog和binlog格式并设置mysql的server_id

# my.cnf里配置
log-bin=mysql-bin
binlog-format=ROW
server_id=1

# 查看bin-log是否开启 on: 开启 off: 关闭

show variables like 'log_bin';

# 最后可以选择是否需要创建一个新的mysql用户进行配置canal(只拥有读取权限)

create user canal identified by 'canal';

grant select,replication slave, replication client on *.* to 'canal'@'%';

flush privileges;

# 注意如果是mysql8以上创建的用户连接时可能会出现caching_sha2_password错误,可以自行查询资料解决修改新创建的用户密码校验规则(plugin:mysql_native_password)即可,也可执行:ALTER USER 'canal'@'%' IDENTIFIED WITH mysql_native_password BY 'canal';(如果还是不行再自己查阅资料吧,不多说,继续我们的流程)

7、canal配置连接mysql ,进入到挂载的conf目录中去,然后编辑配置文件instance.properties

cd /home/canal/conf
vi instance.properties

# 注意需要把该行前面的井号#去掉,并修改值为唯一性(不与mysql的主从设置的值为一,单机可忽略,仅需考虑主的值不一样即可)

canal.instance.mysql.slaveId=200

# 数据库连接与账号密码

canal.instance.master.address=127.0.0.1:3306

canal.instance.dbUsername=canal
canal.instance.dbPassword=canal

修改为自己的数据库连接信息即可

注意:本例子为监听所有库表资源更新状态,如需指定可以配置,(后面也会提这个问题)

canal.instance.filter.regex=.*\\..*(库名.表民)多个可以用逗号隔开

黑名单不多说了,自己去看看资料吧

canal.instance.filter.black.regex=

 8、直接重启一下canal看看日志是否连接成功(进入/home/canal/logs/example下查看日志)

docker安装canal1.1.5监控mysql的binlog日志并配置rocketmq进行数据同步到elasticsearch(超级大干货)

9、开始配置rocketmq啦(安装rocketmq本文不多说)

cd /home/canal/conf
vi canal.properties

主要修改以下数据

canal.serverMode = rocketMQ

rocketmq.producer.group = canal_group
rocketmq.enable.message.trace = false
rocketmq.customized.trace.topic = canal_topic
rocketmq.namespace =
rocketmq.namesrv.addr = xxx.xxx.xxx.xxx:9876
rocketmq.retry.times.when.send.failed = 0
rocketmq.vip.channel.enabled = false
rocketmq.tag =

vi instance.properties

 主要修改以下数据

canal.mq.topic=canal_topic

好啦!!!可以重启一下canal容器啦,重启完毕后,我就随便去数据库修改一条记录,mq就收到消息啦,以下截图仔细查阅 

 docker安装canal1.1.5监控mysql的binlog日志并配置rocketmq进行数据同步到elasticsearch(超级大干货)

 docker安装canal1.1.5监控mysql的binlog日志并配置rocketmq进行数据同步到elasticsearch(超级大干货)

注意:mq虽然有消息啦,但是有个问题,就是无论任何库任何表的数据发生修改都会往同一个topic发送消息,那这样就会导致后端同一个消费者然后再去根据表名分发业务等等问题,更要考虑消息阻塞等问题,所以还是需要把topic改为动态的啦!!!

修改内容如下:

        把instance.properties文件里的canal.mq.topic=canal_topic注释掉,并把#canal.mq.dynamicTopic=mytest1.user,mytest2\\..*,.*\\..*的注释删除掉,并修改为canal.mq.dynamicTopic=.*\\..*,好啦,就是这么简单,还要很多匹配规则,自行去查阅资料吧,这样一来,我们的topic的生成规格是(库名_表名,例如产品库的产品表的topic为:product_db_product_info)

 再注意:由于现在我们所有表的的增删改操作都会往mq发送消息,那这样就更不符合生产啦,简单来说就是瞎几把乱搞?直接就改为指定监听哪些库的哪些表

修改内容如下:

        把instance.properties文件里的canal.instance.filter.regex=.*\\..*改为canal.instance.filter.regex=库名.表名(多个直接用逗号分割),还要其他匹配规格,自行查阅哟,这样就可以啦

 完事后,再来测试一发,看截图

docker安装canal1.1.5监控mysql的binlog日志并配置rocketmq进行数据同步到elasticsearch(超级大干货)

 docker安装canal1.1.5监控mysql的binlog日志并配置rocketmq进行数据同步到elasticsearch(超级大干货)

 10、以上步骤完成后,就可以编写我们的mq消费者啦(例子使用的是rocketmq和java语言哟,后续补上哟)文章来源地址https://www.toymoban.com/news/detail-467147.html

到了这里,关于docker安装canal1.1.5监控mysql的binlog日志并配置rocketmq进行数据同步到elasticsearch(超级大干货)的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • docker安装canal入门实战,同步mysql数据到elasticsearch

    官方docker安装说明文档:https://github.com/alibaba/canal/wiki/Docker-QuickStart canal.adapter canal 1.1.1版本之后, 增加客户端数据落地的适配及启动功能, 目前支持功能: 客户端启动器 同步管理REST接口 日志适配器, 作为DEMO 关系型数据库的数据同步(表对表同步), ETL功能 HBase的数据同步(表对表

    2024年02月04日
    浏览(46)
  • mysql的binlog日志

    一、查看和配置binlog 1、log_bin 是否开启binlog,指定日志文件路径 2、log_bin_basename 和 log_bin_index 日志文件基础名和索引名(*好像不能用来设置只是展示作用,我设置时时会报错无法启动服务) 3、binlog_format 日志格式 4、binlog_error_action 设置当binlog日志数据一致性遭到破坏或者复

    2024年02月16日
    浏览(41)
  • 【mysql】binlog日志

    1.1 基本说明 1.全称binary log,二进制日志 2.记录了所有的DDL语句(Data Definition Language数据定义语言)和DML语句(Data Manipulation /məˌnɪpjuˈleɪʃn/ Language数据操作语言) 3.不包括数据查询语句(select、show) 4.作用:灾难时的数据恢复;mysql的主从复制 5.mysql8.0版本,默认二进制日

    2024年02月13日
    浏览(36)
  • MySQL 日志之二进制日志-binlog

    1、简介         MySQL 的二进制日志记录了对 MySQL 所有的更改操作,不包括 select 和 show 等操作。二进制日志文件主要有:数据恢复、主从复制、审计(判断是否有注入攻击)等作用。 2、二进制日志参数配置 2.1、文件参数配置         linux 中 MySQL的配置文件在 /etc/my.cnf,通

    2024年01月21日
    浏览(64)
  • mysql三大日志—— 二进制日志binlog

    binlog用于记录数据库执行的写入性操作,是一种 逻辑日志 ,binlog 处于服务层 ,通过 追加写入 的方式以二进制的形式保存在磁盘中。 binlog主要用于 主从复制 和数据恢复。 主从复制:在主机端开启binlog日志管理,主机将binlog日志发送到各个从机,从机来读取binlog文件来做到

    2024年02月13日
    浏览(45)
  • 开启MySQL的binlog日志

    查看MySQL的binlog模式   几个关于binlog常用的命令   binlog 就是binary log,二进制日志文件,这个文件记录了mysql所有的dml操作。通过binlog日志我们可以做数据恢复,做主住复制和主从复制等等。对于开发者可能对binlog并不怎么关注,但是对于运维或者架构人员来讲是非常重要的

    2024年01月21日
    浏览(85)
  • Mysql之binlog日志浅析

      Binlog是MySQL数据库中的二进制日志,用于记录数据库中所有修改操作,包括增删改等操作。binlog以二进制格式保存,可以通过解析binlog文件来查看数据库的操作历史记录。binlog日志可以用于数据恢复、数据备份、数据同步等场景。在MySQL数据库中,binlog有两种模式:state

    2024年02月02日
    浏览(57)
  • mysql binlog 日志详解及恢复

    一、binlog概述 binlog是Mysql sever层维护的一种二进制日志,与innodb引擎中的redo/undolog是完全不同的日志; 其主要是用来记录对mysql数据更新或潜在发生更新的SQL语句,并以\\\"事务\\\"的形式保存在磁盘中; 作用主要有: 复制:MySQL Replication在Master端开启binlog,Master把它的二进制日志传

    2024年02月12日
    浏览(46)
  • mysql关闭binlog日志,删除binlog数据(win和linux通用)

    打开 mysql 命令窗口,查询 binlog 是否开启   (ON)为开启状态 (OFF)为关闭状态 若开启状态则需要修改配置文件,反之不需要任何操作 在 C:ProgramDataMySQLMySQL Server 8.0 路径下打开 my.ini 并注释掉 bin-log 配置项然后在其后面加入skip-log-bin   重启mysql服务   打开 mysql 命令窗口,

    2024年02月07日
    浏览(39)
  • 开启MySQL二进制日志(binlog)

    前言 binlog即二进制日志 Binary Log,它记录了所有的DDL和DML(除了数据查询语句)语句,以事件形式记录,还包含语句所执行的消耗的时间,MySQL的二进制日志是事务安全型的。一般来说开启二进制日志大概会有一定的性能损耗。 二进制日志有两个最重要的使用场景: Mysql主从复制

    2023年04月09日
    浏览(62)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包