子流程支持
一些if…else
和发布-订阅
组件可以通过使用子流程来指定其逻辑或映射。最简单的示例是.publishSubscribeChannel()
,如下例所示
@Bean
public IntegrationFlow subscribersFlow() {
return flow -> flow
.publishSubscribeChannel(Executors.newCachedThreadPool(), s -> s
.subscribe(f -> f
.<Integer>handle((p, h) -> p / 2)
.channel(c -> c.queue("subscriber1Results")))
.subscribe(f -> f
.<Integer>handle((p, h) -> p * 2)
.channel(c -> c.queue("subscriber2Results"))))
.<Integer>handle((p, h) -> p * 3)
.channel(c -> c.queue("subscriber3Results"));
}
您可以使用单独的IntegrationFlow
@Bean
定义来实现相同的结果,但我们希望您发现子流程样式的逻辑组合很有用。我们发现它会导致代码更短(因此更易读)。
从 5.3 版开始,提供了一个基于BroadcastCapableChannel
的publishSubscribeChannel()
实现,用于在代理支持的消息通道上配置子流程订阅者。例如,我们现在可以在Jms.publishSubscribeChannel()
上配置多个订阅者作为子流程
@Bean
public JmsPublishSubscribeMessageChannelSpec jmsPublishSubscribeChannel() {
return Jms.publishSubscribeChannel(jmsConnectionFactory())
.destination("pubsub");
}
@Bean
public IntegrationFlow pubSubFlow(BroadcastCapableChannel jmsPublishSubscribeChannel) {
return f -> f
.publishSubscribeChannel(jmsPublishSubscribeChannel,
pubsub -> pubsub
.subscribe(subFlow -> subFlow
.channel(c -> c.queue("jmsPubSubBridgeChannel1")))
.subscribe(subFlow -> subFlow
.channel(c -> c.queue("jmsPubSubBridgeChannel2"))));
}
类似的发布-订阅
子流程组合提供了.routeToRecipients()
方法。
另一个示例是在.filter()
方法上使用.discardFlow()
而不是.discardChannel()
。
.route()
值得特别注意。请考虑以下示例
@Bean
public IntegrationFlow routeFlow() {
return f -> f
.<Integer, Boolean>route(p -> p % 2 == 0,
m -> m.channelMapping("true", "evenChannel")
.subFlowMapping("false", sf ->
sf.<Integer>handle((p, h) -> p * 3)))
.transform(Object::toString)
.channel(c -> c.queue("oddChannel"));
}
.channelMapping()
继续像在常规Router
映射中一样工作,但.subFlowMapping()
将该子流程绑定到主流程。换句话说,任何路由器的子流程在.route()
之后都返回到主流程。
有时,您需要从
Caused by: org.springframework.beans.factory.BeanCreationException: The 'currentComponent' (org.springframework.integration.router.MethodInvokingRouter@7965a51c) is a one-way 'MessageHandler' and it isn't appropriate to configure 'outputChannel'. This is the end of the integration flow. 当您将子流程配置为 lambda 时,框架会处理与子流程的请求-回复交互,并且不需要网关。 |
子流程可以嵌套到任何深度,但我们不建议这样做。实际上,即使在路由器的情况下,在流程中添加复杂的子流程也会很快开始看起来像一盘意大利面,并且难以让人类解析。
在 DSL 支持子流程配置的情况下,当通常需要一个通道来配置正在配置的组件时,并且该子流程以
框架在内部创建一个 |