做设计灵感的网站,广州企业建站网站,做网站兼容性怎么设置,成都网站搭建公司哪家便宜Debezium日常分享系列之#xff1a;Debezium 2.7.0.Alpha2发布 新功能和改进1.Oracle ROW_ID 包含在更改事件中2.带有 JDBC 接收器的 PostreSQL 数组3.Oracle 使用自定义模式名称刷新表4.使用 JWT/seed 进行 NATS 身份验证5.Oracle 大量表查询过滤器 新功能和改进
1.Oracle R… Debezium日常分享系列之Debezium 2.7.0.Alpha2发布 新功能和改进1.Oracle ROW_ID 包含在更改事件中2.带有 JDBC 接收器的 PostreSQL 数组3.Oracle 使用自定义模式名称刷新表4.使用 JWT/seed 进行 NATS 身份验证5.Oracle 大量表查询过滤器 新功能和改进
1.Oracle ROW_ID 包含在更改事件中
虽然 ROW_ID 在表的生命周期中在表的所有行中并不是唯一的但它可以在以非常严格的方式管理表和行的生命周期的某些情况下使用。应社区的要求我们在 Oracle 连接器的更改事件源信息块中添加了新的 row_id 字段。在以下条件下此新字段将填充 ROW_ID 值 仅从插入、更新和删除的流事件填充。快照 evnet 将不包含 row_id 值。仅由 LogMiner 和 XStream 流适配器提供不支持 OpenLogReplicator。
任何不符合条件的事件都不会包含 row_id 字段因为它被标记为可选。
2.带有 JDBC 接收器的 PostreSQL 数组
JDBC 接收器连接器支持使用将源列映射到基于 Kafka ARRAY 的有效负载字段类型。借助 Debezium 2.7您现在可以将基于 ARRAY 的字段序列化到目标 PostgreSQL 数据库而无需更改配置。新的支持应该是完全透明的。
3.Oracle 使用自定义模式名称刷新表
在 Debezium 的早期版本中Oracle 连接器经过严格设计在连接器用户帐户的默认表空间中创建 LogMiner 刷新表。在用户的默认表空间可能不是理想目标并且 DBA 希望该表存在于单独的表空间中的情况下这并不总是有用。以前用户需要修改用户帐户或使用具有正确表空间的新用户才能在正确的表空间位置创建表。在 Debezium 2.7 中不再需要这样做您可以安全地将目标模式/表空间的名称包含在配置中。
使用自定义架构名称的示例
log.mining.flush.table.nameTHE_OTHER_SCHEMA.LOG_MINING_FLUSH_TABLE架构名称是可选的如果未提供连接器将继续使用相同的旧行为即创建刷新表并检查其是否存在于用户的默认表空间中。
4.使用 JWT/seed 进行 NATS 身份验证
Debezium Server NAT 流接收器适配器得到改进支持基于 JWT/种子的身份验证。要开始使用 JWT/基于种子的身份验证请在配置中提供以下必要值
JWT 身份验证示例
debezium.sink.nats-jetstream.auth.jwtyour_jwt_token种子认证示例
debezium.sink.nats-jetstream.auth.seedyour_nkey_seed5.Oracle 大量表查询过滤器
Debezium Oracle 连接器可以在单个连接器部署中轻松支持数千个表但是您可能发现您想要使用 IN 模式自定义查询过滤器。此模式用于以下情况您可能对其他表进行大量更改并且希望在将更改传递到 Debezium 进行处理之前在数据库级别过滤掉该数据集。
在早期版本中用户可能已经注意到将 log.mining.query.filter.mode 设置为 in 值并且表包含列表包含超过 1000 个元素会生成 SQL 错误。 Oracle 不允许子句中包含超过 1000 个元素然而Debezium 2.7 通过在包含 1000 个项目内条款列表的多个存储桶之间使用析取来解决此限制。