集成流组合
在 Spring Integration 中,MessageChannel
抽象被视为一等公民,因此集成流的组合一直被认为是理所当然的。流中任何端点的输入通道都可以用来从任何其他端点发送消息,而不仅仅是从将该通道作为输出的端点发送消息。此外,使用 @MessagingGateway
合约、内容丰富器组件、复合端点(如 <chain>
)以及现在的 IntegrationFlow
bean(例如 IntegrationFlowAdapter
),将业务逻辑分布到更短、可重用的部分变得非常简单。最终组合所需的一切只是关于要发送或接收的 MessageChannel
的知识。
从版本 5.5.4
开始,为了更多地从 MessageChannel
中抽象出来,并隐藏实现细节,IntegrationFlow
引入了 from(IntegrationFlow)
工厂方法,允许从现有流的输出开始当前 IntegrationFlow
。
@Bean
IntegrationFlow templateSourceFlow() {
return IntegrationFlow.fromSupplier(() -> "test data")
.channel("sourceChannel")
.get();
}
@Bean
IntegrationFlow compositionMainFlow(IntegrationFlow templateSourceFlow) {
return IntegrationFlow.from(templateSourceFlow)
.<String, String>transform(String::toUpperCase)
.channel(c -> c.queue("compositionMainFlowResult"))
.get();
}
另一方面,IntegrationFlowDefinition
添加了一个 to(IntegrationFlow)
终端操作符,用于在其他流的输入通道处继续当前流。
@Bean
IntegrationFlow mainFlow(IntegrationFlow otherFlow) {
return f -> f
.<String, String>transform(String::toUpperCase)
.to(otherFlow);
}
@Bean
IntegrationFlow otherFlow() {
return f -> f
.<String, String>transform(p -> p + " from other flow")
.channel(c -> c.queue("otherFlowResultChannel"));
}
流中间的组合可以通过现有的 gateway(IntegrationFlow)
EIP 方法轻松实现。这样,我们可以通过将流组合成更简单、可重用的逻辑块来构建任何复杂度的流。例如,您可以将 IntegrationFlow
bean 库添加为依赖项,只需将它们的配置类导入到最终项目并自动装配到您的 IntegrationFlow
定义中即可。