Spring Integration(集成)原生镜像支持_API

从版本 6.0 开始,Spring AOT​ 本机提示支持 Spring Integration 应用程序的 GraalVM 编译为本机映像。 对于最常见的用例,例如使用方法的端点定义、使用 lambda 的 Java DSL 配置和接口扫描(导入),框架提供了相应的反射、代理和序列化提示。 如果配置在 POJO 方法上使用消息传递注释(等),或者 POJO 方法与 API 一起使用,则还必须使用注释来标记它们,因为它们是由框架反射性调用的。​​@Bean​​​​@MessagingGateway​​​​@ServiceActivator​​​​@Splitter​​​​IntegrationFlowBuilder.handle(Object service, String methodName)​​​​@Reflective​

本机映像不支持 XML 配置。

如前所述,带有注释的服务接口在被 扫描或在注释中使用时,由框架处理,并且相应的代理提示将公开到 AOT 贡献中。 使用 API 声明网关时,必须手动公开为此类接口配置的代理:​​@MessagingGateway​​​​@IntegrationComponentScan​​​​@Import​​​​IntegrationFlow.from(Class<?> serviceInterface)​

@Configuration
@EnableIntegration
@ImportRuntimeHints(GatewayRuntimeHints.class)
public class IntegrationConfiguration {

@Bean
IntegrationFlow someFlow() {
return IntegrationFlow.from(SomeGateway)
// ...
.get();
}

public interface SomeGateway {

void doSomething(Object payload);

}

private static class GatewayRuntimeHints implements RuntimeHintsRegistrar {

@Override
public void registerHints(RuntimeHints hints, ClassLoader classLoader) {
hints.proxies().registerJdkProxy(
AopProxyUtils.completeJdkProxyInterfaces(SomeGateway));
}

}

}

在 AOT 处理阶段不会处理内容。 因此,目标应用程序必须提供一些提示,例如上面提到的网关代理提示。​​IntegrationFlow​

当然,配置只是集成解决方案的一部分。 最重要的部分是通过网络以及持久存储进行数据传输。 这就是序列化在许多用例中派上用场的地方。 Spring 集成将序列化提示公开到框架内部使用的这些类型的本机映像配置中:、、、 对于用户特定的数据(主要显示为消息有效负载),序列化提示必须通过实现手动公开,如上所示的网关代理和相应的 API。​​String​​​​Number​​​​Long​​​​Date​​​​ArrayList​​​​HashMap​​​​Properties​​​​Hashtable​​​​Exception​​​​UUID​​​​GenericMessage​​​​ErrorMessage​​​​MessageHeaders​​​​AdviceMessage​​​​MutableMessage​​​​MutableMessageHeaders​​​​MessageGroupMetadata​​​​MessageHolder​​​​MessageMetadata​​​​MessageHistory​​​​MessageHistory.Entry​​​​DelayHandler.DelayedMessageWrapper​​​​RuntimeHintsRegistrar​​​​RuntimeHints.serialization().registerType()​

建议使用 Spring Boot 开发本机集成应用程序,使用其各自的构建工具。