5.3. 排序交付


幂等生产者避免重复,因为消息会完全传递一次。将 ID 和序列号分配给消息以确保交付顺序,即使在出现故障时也是如此。如果您使用 acks=all 进行数据一致性,使用 idempotency 对排序交付有意义。默认情况下,为制作者启用 idempotency。启用 idempotency 后,您可以将并发动态请求数设置为最多 5 个消息排序。

使用 idempotency 排序交付

# ...
enable.idempotence=true 1
max.in.flight.requests.per.connection=5 2
acks=all 3
retries=2147483647 4
# ...

1
设置为 true 以启用幂等制作者。
2
通过幂等交付动态请求数时,可能会大于 1,同时仍然提供消息排序保证。默认值为 5 个动态请求。
3
acks 设置为 all
4
设置重新发送失败消息请求的尝试次数。

如果您选择不使用 acks=all 并禁用 idempotency,因为性能成本,请将 in-flight (未确认)请求数设置为 1 以保留排序。否则,在 Message-B 写入代理后,Message-A 才会成功。

在没有 idempotency 的情况下排序交付

# ...
enable.idempotence=false 1
max.in.flight.requests.per.connection=1 2
retries=2147483647
# ...

1
设置为 false 以禁用幂等制作者。
2
将动态请求数设置为正好 1
Red Hat logoGithubRedditYoutubeTwitter

学习

尝试、购买和销售

社区

关于红帽文档

通过我们的产品和服务,以及可以信赖的内容,帮助红帽用户创新并实现他们的目标。

让开源更具包容性

红帽致力于替换我们的代码、文档和 Web 属性中存在问题的语言。欲了解更多详情,请参阅红帽博客.

關於紅帽

我们提供强化的解决方案,使企业能够更轻松地跨平台和环境(从核心数据中心到网络边缘)工作。

© 2024 Red Hat, Inc.