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 方法的逻辑是先提交上一批消息的位移,再处理下一批消息,提交顺序问题导致重复消费

相关推荐
二进制_博客8 小时前
flume抽取kafka数据到kafka,数据无法从topicA抽取到topicB
大数据·kafka·flume
少废话h9 小时前
Flume Kafka源与汇的topic覆盖问题解决
java·linux·kafka·flume
她说..10 小时前
基于Redis实现的分布式唯一编号生成工具类
java·数据库·redis·分布式·springboot
西岭千秋雪_10 小时前
Kafka客户端参数(一)
java·分布式·后端·kafka·linq
q***494510 小时前
分布式监控Skywalking安装及使用教程(保姆级教程)
分布式·skywalking
列星随旋11 小时前
初识RabbitMQ
分布式·rabbitmq·ruby
小坏讲微服务11 小时前
Docker-compose搭建Docker Hub镜像仓库整合SpringBootCloud
运维·分布式·spring cloud·docker·云原生·容器·eureka
zl97989911 小时前
RabbitMQ-交换机
分布式·rabbitmq
回家路上绕了弯11 小时前
包冲突排查指南:从发现到解决的全流程实战
分布式·后端
d***93512 小时前
集成RabbitMQ+MQ常用操作
分布式·rabbitmq