PublishSubscribeChannel

PublishSubscribeChannel

我正在尝试将异常发布到特定的错误通道。
我同样使用MessagePublishingErrorHandler

但是我的错误并未发送到我创建的频道。

这是我的代码:

渠道:-

@Bean(value = "appErrorChannel")
    public PublishSubscribeChannel appErrorChannel() {
        return new PublishSubscribeChannel();
    }


MessageHandler:

@Bean
    public MessagePublishingErrorHandler myMessagePublishingErrorHandler(@Qualifier("appErrorChannel") PublishSubscribeChannel errChannel) {
        MessagePublishingErrorHandler messagePublishingErrorHandler = new MessagePublishingErrorHandler();
        messagePublishingErrorHandler.setDefaultErrorChannel(errChannel);
        return messagePublishingErrorHandler;
    }


从该频道访问:

@Bean
public IntegrationFlow errorFlow(@Qualifier("appErrorChannel") PublishSubscribeChannel errChannel) {
    return flow -> flow.channel(errChannel).
            publishSubscribeChannel(spec -> spec
                    .subscribe(f1 -> f1.handle(m -> System.out.println("******************* "+ m.getPayload()))));
}


我原来的频道。 act方法引发异常:-

@Bean
    public IntegrationFlow pubSubFlow(PublishSubscribeChannel publishSubscribeChannel,
                                      @Qualifier("myMessagePublishingErrorHandler")
            MessagePublishingErrorHandler messagePublishingErrorHandler) {
        return flow -> flow.channel(publishSubscribeChannel).split()
                .channel(new ExecutorSubscribableChannel(Executors.newFixedThreadPool(1)))
                .publishSubscribeChannel(config -> config
                .subscribe(f1 -> f1.handle("action", "act")
                        .handle(m1 -> {System.out.println(">>>"+m1);}))
                        .errorHandler(messagePublishingErrorHandler)
                );
    }

最佳答案

errorHandler仅与taskExecutor中的PublishSubscribeChannel一起使用的问题。否则,它将被忽略。在WARN初始化期间,我们可能需要对此事进行PublishSubscribeChannel。随时提出此事的JIRA。

作为解决方法,您可以执行以下操作:

.publishSubscribeChannel(new SyncTaskExecutor(), config -> config


这样,您仍然在同一个调用线程中,但是Runnable.run()确实将被包装到try...catch()中,并且ErrorMessage将被发布到您的appErrorChannel中。

07-25 23:57