CDC: 如何为 MySQL 做快照

298 天前
 GopherDaily

DebeziumKafka Connect 生态体系下的一个 source connector, 支持实时将 MySQL, PostgreSQL 等数据库的变更事件转化为 Kafka 的消息. 随后, 我们可以通过种类丰富的 sink 将数据导入其他数据源.

本文以 MySQL 为例, 简单介绍 Debezium 在初次创建 connector 时为数据库做快照的策略.

Debezium 优先会选择全局读锁来限制表结构的变更, 对应 SQL FLUSH TABLES WITH READ LOCK. 在无法获取全局读锁的情况下, Debezium 需要为每一张表单独加锁, 对应 SQL FLUSH TABLE {} WITH READ LOCK.

优先使用全局读锁而非表锁的主要原因在于:

扫表

这个操作其实在业务上也会比较常见, 一些人会错误的通过不断更新 OFFSET 来实现扫全表. 在稍有规模的数据集就会发现当 OFFSET 变大时, SQL 执行的很慢. 于是更换成浮标式的分页, 即使用当前查询的主键做为下次查询的限制条件, 规避对 OFFSET 的需求.

Debezium 利用 JDBC 提供的 stream 概念简化了逻辑的同时, 提高了效率. 从使用上看, 通过设置 TYPE_FORWARD_ONLYCONCUR_READ_ONLY, JDBC 会实现类似 lazy load 的效果. 先加载 n 条数据, 当用户需要 n+1th 数据时再加载 n 条数据.

虽然没有去看 JDBC 具体的实现, 但是结合文档中提及的内容, 我们可以猜测:

1093 次点击
所在节点    MySQL
1 条回复
liprais
298 天前
jdbc 本来就可以设置 fetch size

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/957943

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX