kafka中,使用ack提交时,存在重复消费问题

ack提交时,存在重复消费??

往consumer监听的topic中,增加了一条数据,但是代码消费了好几次,而且确实也走ack.acknowledge();这块逻辑了,因为处理的逻辑是要入库的,导致数据多了好几条,后排查得知是配置问题

...

spring.kafka.consumer.enable-auto-commit=true

spring.kafka.consumer.auto-offset-reset=latest

代码是刚拿到手,没有注意这块配置问题,因为上述配置导致重复消费,改成下面这种就可以了

...

spring.kafka.consumer.enable-auto-commit=false

spring.kafka.consumer.auto-offset-reset=latest

原因:一旦设置了 enable.auto.commit 为 true,Kafka 会保证在开始调用 poll 方法时,提交上次 poll 返回的所有消息。从顺序上来说,poll 方法的逻辑是先提交上一批消息的位移,再处理下一批消息,提交顺序问题导致重复消费

相关推荐
隰有游龙2 小时前
hadoop集群启动没有datanode解决
大数据·hadoop·分布式
UCoding2 小时前
我们来学zookeeper -- 集群搭建
分布式·zookeeper
小马哥编程3 小时前
【ISAQB大纲解读】Kafka消息总线被视为“自下而上设计”?
分布式·kafka·系统架构·linq
shangjg33 小时前
Kafka 的 ISR 机制深度解析:保障数据可靠性的核心防线
java·后端·kafka
大数据004 小时前
Docker慢慢学
mysql·docker·kafka·n8n
帅气的小峰7 小时前
1-【源码剖析】kafka核心概念
分布式·kafka
xiaolin03337 小时前
【RabbitMQ】- Channel和Delivery Tag机制
分布式·rabbitmq
不吃饭的猪8 小时前
记一次运行spark报错
大数据·分布式·spark
qq_463944868 小时前
【Spark征服之路-2.1-安装部署Spark(一)】
大数据·分布式·spark
昭阳~9 小时前
Kafka深度技术解析:架构、原理与最佳实践
分布式·架构·kafka