有很多场景会导致Consumer消费重复消息
为了保证不消耗重复的消息,作业的执行和提交偏移量必须是原子的,以保证消费者端的一次性传递语义。您可以使用以下参数来实现精确的一种语义。但请您理解,这会牺牲性能。
在Kafka Stream中,可以通过将Exactly-Once语义设置为true以使其成为单位事务来实现上述设置
幂等
幂等传递使生产者能够在单个生产者的生命周期内将消息准确地写入 Kafka 一次到主题的特定分区,而不会丢失数据和每个分区的顺序。
事务(隔离级别)
事务使我们能够自动更新多个主题分区中的数据。一笔交易中包含的所有记录都会被成功保存,或者全部都不保存。它允许您在同一事务中提交消费者偏移量以及已处理的数据,从而允许端到端的一次语义。
生产者不会等待向 Kafka 写入消息,而生产者使用 beginTransaction、commitTransaction 和 abortTransaction(如果发生故障),消费者使用隔离。级别为 read_commissed 或 read_uncommissed
更详细的请参考参考
| 归档时间: |
|
| 查看次数: |
11865 次 |
| 最近记录: |