@KafkaListener注解

bash 复制代码
@KafkaListener(topics = "${xxxx}", containerFactory = "xxx")
public void consume(String message) {
    service.save(xx);
}

在 Spring Boot 中,使用 @KafkaListener 注解消费 Kafka 消息时,如果 service.save(cleanWikiSource) 抛出异常,消息不会被认为已经成功消费完毕。相应的行为取决于 Kafka 配置的 ack 模式以及错误处理机制:

默认情况(ack 模式为 BATCH 或 RECORD):

如果 service.save(cleanWikiSource) 抛出异常,Kafka 会自动将消息标记为未成功消费,并会重新尝试交付此消息(即消息会被重新消费)。

如果配置了 max.poll.interval.ms 或 max.poll.records 等参数,可以控制消费者重试间隔和次数。

手动确认(ack 模式为 MANUAL 或 MANUAL_IMMEDIATE):

如果您启用了手动提交确认(通过 KafkaListener 配置 ackMode = MANUAL),则在成功处理完消息后需手动调用 Acknowledgment.acknowledge() 方法标记消息已被消费。

如果 cleanWikiSourceService.save 方法失败且没有调用 acknowledge(),那么消息将会被重新投递。

错误处理机制:

可以配置 SeekToCurrentErrorHandler(适用于 KafkaListenerContainerFactory)来处理消费异常。此类错误处理器允许指定重试次数和延迟时间,消息在达到最大重试次数后将跳过或交给死信队列。

相关推荐
ppo_wu8 分钟前
关闭kafka在控制台打印的日志
分布式·kafka·springboot
工作不忙6 小时前
不使用docker-compose不使用zookeeper启动ApacheKafka3.8.0单机运行KRAFT模式
ubuntu·docker·zookeeper·kafka·apache
御前一品带刀侍卫9 小时前
springboot整合kafka
大数据·spring boot·kafka
管理大亨10 小时前
大数据之Kafka集群的安装部署
大数据·kafka·linq
yangjiwei020717 小时前
Flume采集Kafka数据到Hive
hive·kafka·flume
ok你也是个coder17 小时前
Kafka 基础入门
分布式·kafka·mq·kafka入门
陈序缘21 小时前
Rust实现Kafka - 前言
开发语言·分布式·后端·职场和发展·rust·kafka
Mephisto.java1 天前
【大数据学习 | kafka】kafka的shell操作
大数据·学习·kafka
MinIO官方账号1 天前
使用 Kafka 和 MinIO 实现人工智能数据工作流
人工智能·microsoft·kafka
java1234_小锋2 天前
Kafka 与传统 MQ 消息系统之间有三个关键区别?
分布式·kafka