Flink cdc如何只进行增量同步,不同步历史数据(只读取binlog)

环境

flink: 1.15.3

flink-connector-mysql-cdc: 2.4.0

场景:

mysql cdc到starrocks,

目前线上环境以及有老的任务在同步,现在升级了任务(旧checkpoints无法使用)旧表里面数据特别大,不方便重新同步

方案

思考:表里面的旧数据放着不动,只从binlog同步最新的数据。

解决

https://nightlies.apache.org/flink/flink-cdc-docs-master/zh/docs/connectors/mysql/

这是官网的解决办法,但是没有说参数设置在哪里。起初设置到debeziumProperties()里面是不生效的。

其实MySqlSourceBuilder是有一个方法特意指定startUP mode的

java 复制代码
MySqlSourceBuilder<String> builder = new MySqlSourceBuilder<>();

if (StringUtils.isNotBlank(latestOffset)){
     // 从最新的binlog同步
      builder.startupOptions(StartupOptions.latest());
 }

这样就可以了,重启任务不会读取历史数据。

最后(注意!!!)

执行过后请停止任务从最新的checkpoints恢复,或者记录好checkpoints。否则下次仍然指定这种模式会丢失数据的,还有指定了这个模式不要写死,否则checkpoints会失效的,用参数的方式传入!

相关推荐
小五传输19 小时前
数据摆渡解决方案:平衡安全与效率的企业级选择
大数据·运维·安全
灰鲸广告联盟19 小时前
APP广告变现数据分析:关键指标与优化策略
大数据·网络·数据分析
Hello.Reader19 小时前
Flink OpenSearch SQL Connector Append/Upsert、动态索引、Exactly-Once 与性能调参
大数据·sql·flink
Knight_AL20 小时前
Apache Flink 窗口处理函数全解析(增量 + 全量 + 混合)
大数据·flink·apache
绝缘体120 小时前
企微scrm的核心功能有哪些?
大数据·企业微信
Gazer_S20 小时前
【Git 操作指南:分支同步与冲突批量解决】
大数据·git·elasticsearch
G皮T20 小时前
【Elasticsearch】OpenDistro/Elasticsearch 权限分类详解
大数据·elasticsearch·搜索引擎·全文检索·kibana·权限管理·opensearch
高频交易dragon20 小时前
配对交易策略大观
大数据·人工智能
007张三丰20 小时前
Git 常用使用规范与高效技巧
大数据·git·elasticsearch
weixin_4572971020 小时前
Hadoop面试题
大数据·hadoop·分布式