参考链接: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


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

被折叠的 条评论
为什么被折叠?



