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

相关推荐
攻心的子乐3 小时前
redis分布式锁 多节点部署项目 Redisson 来做分布式锁
数据库·redis·分布式
q***T5834 小时前
后端分布式缓存预热,提高缓存命中率
分布式·缓存
没有bug.的程序员4 小时前
Spring 全家桶在大型项目的最佳实践总结
java·开发语言·spring boot·分布式·后端·spring
q***72565 小时前
【分布式文件存储系统Minio】2024.12保姆级教程
分布式
芭比萌妹6 小时前
apisix的kafka-logger设置日志格式log_format,不支持单个路由设置
分布式·kafka
z***02607 小时前
【RabbitMQ】超详细Windows系统下RabbitMQ的安装配置
windows·分布式·rabbitmq
回家路上绕了弯8 小时前
生产环境服务器变慢?从应急到根因的全流程诊断处理指南
分布式·后端
喵了几个咪12 小时前
Golang微服务框架Kratos应用分布式任务队列Machinery
分布式·微服务·golang
x***587012 小时前
后端分布式缓存一致性哈希,Java实现
分布式·缓存·哈希算法
2501_9411444213 小时前
Java、C# 与 C++:编程语言的选择与应用场景分析
kafka