Debezium日常分享系列之:Debezium 2.7.2.Final Released

Debezium 2.7 版本流的第二个维护版本 2.7.2.Final。此维护版本侧重于解决稳定性和回归问题,并进行了一些改进,例如使用 Informix 支持 DECIMAL§ 数据类型以及修复使用 JsonConverter 和 TruncateColumn 处理程序的回归。

重大变化

Debezium Server Kafka Sink

  • 适配器在Kafka代理不可用时可能会无限等待。为了在达到超时时间时强制适配器失败,已经为sink适配器添加了一个可配置的超时时间。新的选项debezium.sink.kafka.wait.message.delivery.timeout.ms的默认值为30秒。如果默认值不满足您的需求,请相应地进行调整。

SQL Server

普通的JMX指标会注册一个taskId属性,因为SQL Server支持为每个数据库映射生成一个唯一的任务。不幸的是,JMX信号通道没有遵守这一点,导致每个任务启动JMX信号通道时出现了一些问题。这个问题已经修复,JMX信号通道的MBean名称现在在其名称中使用taskId来唯一标识每个数据库任务的信号通道,当使用单个连接器从多个SQL Server数据库中流式传输更改时。

新功能和改进

Informix DECIMAL§数据类型支持

  • 在使用Debezium处理Informix数据库时,DECIMAL数据类型进行了一些改进。该数据类型可以带有或不带有精度。如果没有精度定义,连接器会将该列的类型解释为DECIMAL(16)。但是,用户也可以将列定义为DECIMAL(p,s),其中p是最大可达32位的精度,s是可变刻度。
  • 为了使用精确小数处理模式表示此类十进制数的上限,Informix连接器必须进行调整,以利用Debezium VariableScaleDecimal语义类型。这使得Debezium在将此类浮点数序列化为Kafka消息时保留完整精度。

修复和稳定性改进

Debezium 2.7.2.Final 引入了多个错误修复和稳定性改进。

列截断现在受到JsonConverter的尊重

  • 在早期的Debezium版本中,column.truncate.*功能基于截断配置返回了一个切片的ByteBuffer。虽然在使用Avro时这种方法有效,但是如果您的连接器配置使用JsonConverter,截断将不会被尊重,因为它操作整个底层数组而不是给定的切片。
  • 在Debezium 2.7.2.Final中,这个问题已经得到修复,列截断逻辑现在明确地基于一个新数组创建一个ByteBuffer。这个变化使得JsonConverter能够在序列化到Kafka时尊重截断的列值。

snapshot模式的schema_only_recovery已经恢复

  • 还有报道称,在Debezium 2.7中,schema_only_recovery快照模式无法正常工作。我们已经找到了问题,并且schema_only_recovery快照模式再次成为Debezium 2.7的可行选择。
  • 温馨提示,在Debezium 2.7中,schema_only_recovery和schema_only已经被弃用,并在Debezium 3.0中被移除。在从Debezium 2.7升级到3.0时,请确保分别使用recovery或no_data快照模式。

Debezium Server中缺少MariaDB

  • 一些用户可能已经注意到,随着Debezium 2.7中新增的官方MariaDB连接器,该连接器在Debezium Server发行版中缺失。很高兴告诉大家,Debezium 2.7.2.Final版本的构建中将包含MariaDB连接器,因此您将不再需要手动添加它。

将Oracle VECSYS表空间标记为内置

  • 如果您尝试使用最新的Oracle 23ai镜像之一与Debezium配合使用,您会注意到出现了一个名为VECSYS的新表空间。该表空间包含了各种用于存储有关新的Oracle 23向量数据库和搜索功能的元数据的系统表。
  • 我们发现,用于捕获表的DDL结构的DBMS_METADATA.GET_DDL函数与VECSYS表空间中的几个数据库对象不兼容,如果您不显式将schema.history.internal.store.only.captured.tables.ddl设置为true,将会导致连接器出现问题。为了解决这个问题,该表空间被标记为内置,意味着不再符合捕获的条件。
  • 4
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
### 回答1: 要安装并下载libxml2-2.7.2.tar.gz的过程如下: 首先,确保您使用的是连接互联网的计算机,并且具备管理员权限。接下来,打开您的终端或命令提示符。 首先,我们需要下载libxml2-2.7.2.tar.gz文件。您可以使用以下命令在终端中获取该文件的下载链接: ``` wget https://xmlsoft.org/sources/libxml2-2.7.2.tar.gz ``` 该命令将使用`wget`工具从官方网站下载libxml2-2.7.2.tar.gz文件。 下载完成后,使用以下命令以解压文件: ``` tar -zxvf libxml2-2.7.2.tar.gz ``` 该命令将解压缩libxml2-2.7.2.tar.gz文件。解压缩后,我们可以进入解压缩文件的目录: ``` cd libxml2-2.7.2 ``` 接下来,我们将编译和安装libxml2库。首先,运行以下命令以生成编译配置: ``` ./configure ``` 然后,运行以下命令以开始编译过程: ``` make ``` 编译完成后,运行以下命令进行安装: ``` make install ``` 这将安装libxml2库到您的系统中。 最后,您可以验证安装是否成功,可以使用以下命令检查libxml2库的版本: ``` xml2-config --version ``` 如果显示版本号为2.7.2,那么libxml2库的安装和下载过程就完成了。 希望这些步骤对您有所帮助!请注意,具体的命令可能因操作系统和环境而略有不同。 ### 回答2: 安装下载libxml2-2.7.2.tar.gz可以按照以下步骤进行: 1. 首先,打开您的终端窗口。 2. 使用wget命令下载libxml2-2.7.2.tar.gz文件。您可以在终端中输入以下命令: wget [libxml2-2.7.2.tar.gz的下载链接] 3. 等待下载完成后,使用tar命令解压缩.tar.gz文件。在终端中输入以下命令: tar -zxvf libxml2-2.7.2.tar.gz 4. 进入解压缩后的文件夹。在终端中输入以下命令: cd libxml2-2.7.2 5. 在文件夹中,运行configure命令对源代码进行配置。在终端中输入以下命令: ./configure 6. 配置成功后,运行make命令进行编译。在终端中输入以下命令: make 7. 编译完成后,运行make install命令进行安装。在终端中输入以下命令: sudo make install 8. 等待安装完成后,libxml2-2.7.2.tar.gz将会成功安装在您的系统中。 请注意,安装过程可能因操作系统的不同而有所差异。上述步骤为一般Linux系统上的安装流程。 ### 回答3: 安装并下载libxml2-2.7.2.tar.gz文件需要经过以下步骤: 1. 首先,在你的计算机上打开一个终端窗口。 2. 在终端中,输入以下命令下载libxml2-2.7.2.tar.gz文件: ``` wget http://xmlsoft.org/sources/libxml2-2.7.2.tar.gz ``` 这个命令将使用wget工具从指定的URL下载tar.gz压缩文件。下载完成后,文件将保存在当前工作目录中。 3. 接下来,输入以下命令解压下载文件: ``` tar -zxvf libxml2-2.7.2.tar.gz ``` 这个命令将使用tar工具解压缩.tar.gz文件,并将解压缩得到的文件保存在当前工作目录中。 4. 进入解压缩得到的文件夹: ``` cd libxml2-2.7.2 ``` 这个命令将进入解压缩得到的libxml2-2.7.2文件夹。 5. 接着,输入以下命令进行配置: ``` ./configure ``` 这个命令将根据你的系统环境进行配置。 6. 运行编译命令: ``` make ``` 这个命令将根据配置生成可执行文件。 7. 最后,用以下命令运行安装程序: ``` sudo make install ``` 这个命令将以超级用户权限安装libxml2库文件到系统中。 完成上述步骤后,你将成功地安装和下载了libxml2-2.7.2.tar.gz文件,并且可以在你的系统中使用该库文件了。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

快乐骑行^_^

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值