DSL 和端点配置
所有IntegrationFlowBuilder
EIP 方法都有一个变体,该变体应用 lambda 参数来为AbstractEndpoint
实例提供选项:SmartLifecycle
、PollerMetadata
、request-handler-advice-chain
等。它们每个都有泛型参数,因此允许您在上下文中配置端点甚至其MessageHandler
,如下例所示
@Bean
public IntegrationFlow flow2() {
return IntegrationFlow.from(this.inputChannel)
.transformWith(t -> t
.transformer(new PayloadSerializingTransformer())
.autoStartup(false)
.id("payloadSerializingTransformer"))
.transformWith(t -> t
.transformer((Integer p) -> p * 2)
.advice(expressionAdvice()))
.get();
}
此外,EndpointSpec
提供了一个id()
方法,允许您使用给定的 bean 名称注册端点 bean,而不是生成的 bean 名称。
如果MessageHandler
被引用为 bean,那么如果 DSL 定义中存在.advice()
方法,则任何现有的adviceChain
配置都将被覆盖
@Bean
public TcpOutboundGateway tcpOut() {
TcpOutboundGateway gateway = new TcpOutboundGateway();
gateway.setConnectionFactory(cf());
gateway.setAdviceChain(Collections.singletonList(fooAdvice()));
return gateway;
}
@Bean
public IntegrationFlow clientTcpFlow() {
return f -> f
.handle(tcpOut(), e -> e.advice(testAdvice()))
.transform(Transformers.objectToString());
}
它们不会合并,在这种情况下只使用testAdvice()
bean。