码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • flink-connector-mysql-cdc


    FlinkCDC是一个实现CDC(Change Data Capture)思想的数据同步工具。 借助于Flink CDC Connector ,它监听数据库的二进制日志文件,来获取数据库变更的数据,以此实现数据同步。

    1. 下载Flink 及 对应版本的 Flink CDC

    FlinkCDC 支持的 Connectors and Version

    FlinkCDC 支持的 Flink Versions

    下载 mysql-cdc connector 放入 FLINK_HOME/lib

    启动Flink Cluster : Flink_HOME/bin/start_cluster.sh

    ① 除了使用Flink CDC连接数据库外,也可以使用jdbc方式连接数据库。Flink CDC持续监听数据库二进制日志文件,以此捕获变更数据。而jdbc连接器允许读和写关系型数据库。
    ② 监听数据库变更的数据,既可以使用DataStream方式,也可以使用SQL

    2. 开启MySQL的二进制日志

    vim /etc/my.cnf

    [mysqld]
    server_id=1
    log_bin = mysql-bin
    binlog_format = ROW
    expire_logs_days = 30 #这个配置在公司中不要配,这里是虚拟机环境,可以配置。	
    
    • 1
    • 2
    • 3
    • 4
    • 5

    重启MySQL数据库 :systemctl restart mysqld

    3. mysql-cdc实时捕获MySQL变更数据

    建表规则
    1.字段名必须相同
    2.数据类型必须匹配上
    3.FlinkSQL中的表名无所谓,不需要和MySQL中的源表一样

    create table f_student (
    	s_id string primary key not enforced,
    	s_name string,
    	s_birth string,
    	s_sex string
    ) with (
    	'connector' = 'mysql-cdc',
    	'hostname' = 'node1',
    	'port' = '3306',
    	'username' = 'root',
    	'password' = '123456',
    	'database-name' = 'test',
    	'table-name' = 'Student',
    	'scan.startup.mode' = 'initial',
    	'server-time-zone' = 'Asia/Shanghai'
    );
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16

    scan.startup.mode:
    MySQL CDC 消费者可选的启动模式, 合法的模式为 “initial”,“earliest-offset”,“latest-offset”,“specific-offset” 和 “timestamp”
    更多连接选项在这里

    mysql-cdc实时捕获mysql数据库表Student中变更的数据,包括insert 、update、delete操作,通过select语句查看
    select * from f_student ;
    在这里插入图片描述

    4. jdbc connetcor读写MySQL数据库

    下载Flink jdbc Connector 放入 FLUME_HOME/lib

    ※ flink-docs-release-1.14 检查该路径是否和已安装的flink版本一样

    下载MySQL数据库驱动 放入 FLUME_HOME/lib

    CREATE TABLE f_score(
      s_id STRING,
      c_id STRING,
      s_score INT
    ) WITH (
       'connector' = 'jdbc',
       'url' = 'jdbc:mysql://node1:3306/test',
       'table-name' = 'Score',
       'username' = 'root',
       'password' = '123456'
    );
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11

    flink jdbc connector 读取mysql中的数据,通过select语句查看读取的数据
    select * from f_score;
    在这里插入图片描述

  • 相关阅读:
    算法分析与设计:CH7快排详解(文末附快排完整算法)
    前端笔记2 使用 Webpack 打包前端的资源
    使用遗传算法优化的BP神经网络实现自变量降维
    R语言向前或者向后移动时间序列数据(自定义滞后或者超前的期数):使用dplyr包中的lag函数将时间序列数据向后移动一天(设置参数n为负值)
    设备的分配与回收(考虑因素,数据结构,分配步骤)
    【JavaSE】类和对象(一)
    研发效能认证学员作品:持续集成与持续部署:软件高质量的关键丨IDCF
    一天梳理完react面试高频知识点
    【1++的C++进阶】之C++11(一)
    前辈经验分享:Linux后台开发调试
  • 原文地址:https://blog.csdn.net/weixin_37536020/article/details/132998829
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号