17.5. 将消费者和 Kafka Streams 应用程序升级到合作重新平衡
如果需要,在 Kafka 升级后,您可以升级 Kafka 使用者和 Kafka Streams 应用程序,以使用 增量合作重新平衡 协议进行分区重新平衡,而不是默认的 eager 重新平衡 协议。在 Kafka 2.4.0 中添加新协议。
消费者将分区分配保持在协作重新平衡中,并仅在需要实现均衡的集群时在进程结束时撤销它们。这可减少消费者组或 Kafka Streams 应用程序不可用。
注意
升级到增量协作协议是可选的。仍然在支持预先重新平衡协议。
先决条件
流程
要升级 Kafka 消费者以使用增量合作重新平衡协议:
-
将 Kafka 客户端
.jar
文件替换为新版本。 -
在消费者配置中,将
cooperative-sticky
附加到partition.assignment.strategy
。例如,如果设置了范围
策略,请将配置更改为范围,合作-sticky
。 - 依次重启组中的每个消费者,等待用户在每次重启后重新加入组。
-
通过从消费者配置中删除之前
的分区.assignment.strategy
来重新配置组中的每个消费者,仅让合作策略成为一个合作
策略。 - 依次重启组中的每个消费者,等待用户在每次重启后重新加入组。
要升级 Kafka Streams 应用程序,请使用增量重新平衡协议:
-
将 Kafka Streams
.jar
文件替换为新版本。 -
在 Kafka Streams 配置中,将
upgrade.from
配置参数设置为您要从升级的 Kafka 版本(如 2.3)。 - 依次重启每个流处理器(节点)。
-
从 Kafka Streams 配置中删除
upgrade.from
配置参数。 - 依次重新启动组中的每个消费者。