IT评测·应用市场-qidao123.com技术社区

标题: 通过 Flink CDC CLI 提交任务:整库同步 MySQL 到 Doris [打印本页]

作者: 王國慶    时间: 2025-4-4 03:16
标题: 通过 Flink CDC CLI 提交任务:整库同步 MySQL 到 Doris
Streaming ELT 同步 MySQL 到 Doris #

这篇教程将展示怎样基于 Flink CDC 快速构建 MySQL 到 Doris 的 Streaming ELT 作业,包罗整库同步、表结构变更同步和分库分表同步的功能。 本教程的演示都将在 Flink CDC CLI 中举行,无需一行 Java/Scala 代码,也无需安装 IDE。
准备阶段 #

准备一台已经安装了 Docker 的 Linux 或者 MacOS 电脑。
准备 Flink Standalone 集群 #

启动成功的话,可以在 http://localhost:8081/访问到 Flink Web UI,如下所示:

多次实行 start-cluster.sh 可以拉起多个 TaskManager。
准备 Docker 情况 #

接下来的教程将以 docker-compose 的方式准备所必要的组件。
MacOS 由于内部实现容器的方式不同,在摆设时宿主机直接修改max_map_count值大概无法成功,必要先创建以下容器:
  1. docker run -it --privileged --pid=host --name=change_count debian nsenter -t 1 -m -u -n -i sh
复制代码
容器创建成功实行以下下令:
  1. sysctl -w vm.max_map_count=2000000
复制代码
然后 exit 退出,创建 Doris Docker 集群。
该 Docker Compose 中包罗的容器有:

在 docker-compose.yml 所在目录下实行下面的下令来启动本教程必要的组件:
  1. docker-compose up -d
复制代码
该下令将以 detached 模式自动启动 Docker Compose 设置中定义的所有容器。你可以通过 docker ps 来观察上述的容器是否正常启动了,也可以通过访问http://localhost:8030/ 来查看 Doris 是否运行正常。
在 MySQL 数据库中准备数据 #

Create database in Doris #

Doris 暂时不支持自动创建数据库,必要先创建写入表对应的数据库。
通过 Flink CDC CLI 提交任务 #

3.编写任务设置 yaml 文件。 下面给出了一个整库同步的示例文件 mysql-to-doris.yaml:
  1. ################################################################################
  2. # Description: Sync MySQL all tables to Doris
  3. ################################################################################
  4. source:
  5.   type: mysql
  6.   hostname: localhost
  7.   port: 3306
  8.   username: root
  9.   password: 123456
  10.   tables: app_db.\.*
  11.   server-id: 5400-5404
  12.   server-time-zone: UTC
  13. sink:
  14.   type: doris
  15.   fenodes: 127.0.0.1:8030
  16.   username: root
  17.   password: ""
  18.   table.create.properties.light_schema_change: true
  19.   table.create.properties.replication_num: 1
  20. pipeline:
  21.   name: Sync MySQL Database to Doris
  22.   parallelism: 2
复制代码
其中: source 中的 tables: app_db.\.* 通过正则匹配同步 app_db 下的所有表。 sink 添加 table.create.properties.replication_num 参数是由于 Docker 镜像中只有一个 Doris BE 节点。
提交成功后,返复书息如:
  1. Pipeline has been submitted to cluster.
  2. Job ID: ae30f4580f1918bebf16752d4963dc54
  3. Job Description: Sync MySQL Database to Doris
复制代码
在 Flink Web UI,可以看到一个名为 Sync MySQL Database to Doris 的任务正在运行。

打开 Doris 的 Web UI,可以看到数据表已经被创建出来,数据能成功写入。

同步变更 #

进入 MySQL 容器
  1. docker-compose exec mysql mysql -uroot -p123456
复制代码
接下来,修改 MySQL 数据库中表的数据,Doris 中显示的订单数据也将及时更新:
每实行一步就刷新一次 Doris Web UI,可以看到 Doris 中显示的 orders 数据将及时更新,如下所示:

同样的,去修改 shipments, products 表,也能在 Doris 中及时看到同步变更的结果。
Route the changes #

Flink CDC 提供了将源表的表结构/数据路由到其他表名的设置,借助这种能力,我们能够实现表名库名更换,整库同步等功能。 下面提供一个设置文件说明:
  1. ################################################################################
  2. # Description: Sync MySQL all tables to Doris
  3. ################################################################################
  4. source:
  5.    type: mysql
  6.    hostname: localhost
  7.    port: 3306
  8.    username: root
  9.    password: 123456
  10.    tables: app_db.\.*
  11.    server-id: 5400-5404
  12.    server-time-zone: UTC
  13. sink:
  14.    type: doris
  15.    fenodes: 127.0.0.1:8030
  16.    benodes: 127.0.0.1:8040
  17.    username: root
  18.    password: ""
  19.    table.create.properties.light_schema_change: true
  20.    table.create.properties.replication_num: 1
  21. route:
  22.    - source-table: app_db.orders
  23.      sink-table: ods_db.ods_orders
  24.    - source-table: app_db.shipments
  25.      sink-table: ods_db.ods_shipments
  26.    - source-table: app_db.products
  27.      sink-table: ods_db.ods_products
  28. pipeline:
  29.    name: Sync MySQL Database to Doris
  30.    parallelism: 2
复制代码
通过上面的 route 设置,会将 app_db.orders 表的结构和数据同步到 ods_db.ods_orders 中。从而实现数据库迁移的功能。 特别地,source-table 支持正则表达式匹配多表,从而实现分库分表同步的功能,例如下面的设置:
  1. route:
  2.   - source-table: app_db.order\.*
  3.     sink-table: ods_db.ods_orders
复制代码
这样,就可以将诸如 app_db.order01、app_db.order02、app_db.order03 的表汇总到 ods_db.ods_orders 中。留意,目前还不支持多表中存在类似主键数据的场景,将在后续版本支持。
情况整理 #

本教程结束后,在 docker-compose.yml 文件所在的目录下实行如下下令制止所有容器:
  1. docker-compose down
复制代码
在 Flink 所在目录 flink-1.18.0 下实行如下下令制止 Flink 集群:
  1. ./bin/stop-cluster.sh
复制代码

links:
MySQL 同步到 Doris | Apache Flink CDC

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。




欢迎光临 IT评测·应用市场-qidao123.com技术社区 (https://dis.qidao123.com/) Powered by Discuz! X3.4