繁体   English   中英

Spring Kafka:将 KafkaListenerErrorHandler 应用于所有 KafkaListener

[英]Spring Kafka: applying KafkaListenerErrorHandler to all KafkaListener

我想拦截我的@KafkaListener 抛出的验证错误(MethodArgumentNotValidException)。 为了实现这一点,我创建了实现 KafkaListenerErrorHandler 的 DefaultKafkaValidationErrorHandler:

@Component
public class DefaultKafkaValidationErrorHandler implements KafkaListenerErrorHandler {


    @Override
    public Object handleError(Message<?> message, ListenerExecutionFailedException exception, Consumer<?, ?> consumer) {
       //here is some logic
    }

    @Override
    public final Object handleError(Message<?> message, ListenerExecutionFailedException exception) {
        //such as here
    }
}

并为注册商设置一个验证器:

@Component
public class KafkaListenerConfig implements KafkaListenerConfigurer {
    @Autowired
    private LocalValidatorFactoryBean validator;

    @Override
    public void configureKafkaListeners(KafkaListenerEndpointRegistrar registrar) {
        registrar.setValidator(this.validator);
    }

}

当我将这个处理程序直接放在我的听众身上时它工作正常

@KafkaListener(
            containerFactory = "factory",
            topics = "topic",
            groupId = "group.id",
            errorHandler = "defaultKafkaValidationErrorHandler")

我的问题是,有没有办法将我的 DefaultKafkaValidationErrorHandler 应用到我项目中的所有@KafkaListener,而不是像上面提到的那样直接应用。 也许通过 ConcurrentKafkaListenerContainerFactory、KafkaListenerEndpointRegistrar 或其他方式

您可以覆盖C createListenerContainer(KafkaListenerEndpoint endpoint); ConcurrentKafkaListenerContainerFactory的方法,并将您的全局KafkaListenerErrorHandler设置为所有单个endpoint 您的工厂必须在KafkaListenerAnnotationBeanPostProcessor.DEFAULT_KAFKA_LISTENER_CONTAINER_FACTORY_BEAN_NAME bean 名称下注册,以避免在每个@KafkaListener上配置此工厂。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM