此版本仍在开发中,尚未被视为稳定版本。对于最新的稳定版本,请使用 Spring Integration 6.4.0! |
本机映像支持
从版本 6.0 开始,Spring AOT 原生提示支持将 Spring 集成应用程序编译为原生镜像的 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 使用其各自的构建工具开发本机集成应用程序。 |