SpringBoot-Kafka-监听-禁止自启动问题

本文详细介绍了在SpringBoot中使用Kafka时遇到的消费者启动和关闭问题,特别是关于`ListenerExecutionFailedException`异常,该异常提示侦听器容器必须设置为手动确认模式。通过检查代码发现,`@KafkaListener`注解的`autoStartup`字段可用于控制消费者的启动和停止。示例代码展示了如何配置监听器工厂和监听器容器工厂以禁止自动启动,并提供了一个消费者示例。解决这个问题的关键在于正确配置手动确认模式。

参考链接:SpringBoot - Kafka的集成与使用详解12(消费者7:动态开启、关闭监听)

报错:org.springframework.kafka.listener.ListenerExecutionFailedException: invokeHandler Failed ; nested exception is java.lang.IllegalStaeException: No Acknowledgment available as an argument, the listener container must have a MANUAL Ackmode to populate the Acknowledgment .; nested exception is java.lang.IllegalStaeException: No Acknowledgment available as an argument, the listener container must have a MANUAL Ackmode to populate the Acknowledgment

翻译:没有可用的确认作为参数,侦听器容器必须具有手动确认模式才能填充确认;没有可用的确认作为参数,侦听器容器必须具有手动确认模式才能填充确认

报错截图
在这里插入图片描述
在这里插入图片描述
参考的代码

@Configuration
public class KafkaInitialConfiguration {
 
    // 监听器工厂
    @Autowired
    private ConsumerFactory consumerFactory;
 
    // 监听器容器工厂(设置禁止KafkaListener自启动)
    @Bean
    public ConcurrentKafkaListenerContainerFactory delayContainerFactory() {
        ConcurrentKafkaListenerContainerFactory container =
                new ConcurrentKafkaListenerContainerFactory();
        container.setConsumerFactory(consumerFactory);
        //禁止自动启动
        container.setAutoStartup(false);
        return container;
    }
}
@Component
public class KafkaConsumer {
    // 消费监听
    @KafkaListener(id = "myListener1", topics = {"topic1"},
            containerFactory = "delayContainerFactory")
    public void listen1(String data) {
        System.out.println("监听器收到消息:" + data);
    }
}

试了好几种方式都不行,最后看到注解才发现,已经有字段可以控制了

@KafkaListener
String autoStartup

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值