此版本仍在开发中,尚不被认为是稳定的。对于最新的稳定版本,请使用 Spring Integration 6.5.1! |
FTP 流式入站通道适配器
版本 4.3 引入了流式入站通道适配器。
此适配器生成一条消息,其中包含类型为InputStream
,允许在不写入本地文件系统的情况下获取文件。
由于会话保持打开状态,因此使用应用程序负责在文件使用时关闭会话。
会话在closeableResource
标头 (IntegrationMessageHeaderAccessor.CLOSEABLE_RESOURCE
).
标准框架组件,例如FileSplitter
和StreamTransformer
,自动关闭会话。
有关这些组件的更多信息,请参阅文件拆分器和流转换器。
以下示例演示如何配置inbound-streaming-channel-adapter
:
<int-ftp:inbound-streaming-channel-adapter id="ftpInbound"
channel="ftpChannel"
session-factory="sessionFactory"
filename-pattern="*.txt"
filename-regex=".*\.txt"
filter="filter"
filter-expression="@myFilterBean.check(#root)"
remote-file-separator="/"
comparator="comparator"
max-fetch-size="1"
remote-directory-expression="'foo/bar'">
<int:poller fixed-rate="1000" />
</int-ftp:inbound-streaming-channel-adapter>
只有其中一个filename-pattern
,filename-regex
,filter
或filter-expression
是允许的。
从 5.0 版开始,默认情况下,FtpStreamingMessageSource 适配器可防止远程文件的重复FtpPersistentAcceptOnceFileListFilter 基于内存中的SimpleMetadataStore .
默认情况下,此过滤器也与文件名模式(或正则表达式)一起应用。
如果需要允许重复,可以使用AcceptAllFileListFilter .
任何其他用例都可以通过CompositeFileListFilter (或ChainFileListFilter ).
Java 配置(在文档后面)显示了一种在处理后删除远程文件以避免重复的技术。 |
有关FtpPersistentAcceptOnceFileListFilter
及其使用方式,请参阅远程持久文件列表过滤器。
使用max-fetch-size
属性来限制在需要获取时每次轮询时获取的文件数量。
将其设置为1
并在集群环境中运行时使用持久过滤器。
有关更多信息,请参阅入站通道适配器:控制远程文件获取。
适配器将远程目录和文件名放在FileHeaders.REMOTE_DIRECTORY
和FileHeaders.REMOTE_FILE
标头。
从 5.0 版开始,FileHeaders.REMOTE_FILE_INFO
header 提供额外的远程文件信息(默认以 JSON 表示)。
如果您将fileInfoJson
属性FtpStreamingMessageSource
自false
,标头包含一个FtpFileInfo
对象。
这FTPFile
可以使用FtpFileInfo.getFileInfo()
方法。
这fileInfoJson
属性在使用 XML 配置时不可用,但您可以通过注入FtpStreamingMessageSource
到您的配置类之一。
另请参阅远程文件信息。
从 5.1 版开始,泛型类型comparator
是FTPFile
.
以前,它是AbstractFileInfo<FTPFile>
.
这是因为排序现在是在处理的早期执行的,然后再筛选和应用maxFetch
.
使用 Java 配置进行配置
以下 Spring Boot 应用程序显示了如何使用 Java 配置配置入站适配器的示例:
@SpringBootApplication
public class FtpJavaApplication {
public static void main(String[] args) {
new SpringApplicationBuilder(FtpJavaApplication.class)
.web(false)
.run(args);
}
@Bean
@InboundChannelAdapter(channel = "stream")
public MessageSource<InputStream> ftpMessageSource() {
FtpStreamingMessageSource messageSource = new FtpStreamingMessageSource(template());
messageSource.setRemoteDirectory("ftpSource/");
messageSource.setFilter(new AcceptAllFileListFilter<>());
messageSource.setMaxFetchSize(1);
return messageSource;
}
@Bean
@Transformer(inputChannel = "stream", outputChannel = "data")
public org.springframework.integration.transformer.Transformer transformer() {
return new StreamTransformer("UTF-8");
}
@Bean
public FtpRemoteFileTemplate template() {
return new FtpRemoteFileTemplate(ftpSessionFactory());
}
@ServiceActivator(inputChannel = "data", adviceChain = "after")
@Bean
public MessageHandler handle() {
return System.out::println;
}
@Bean
public ExpressionEvaluatingRequestHandlerAdvice after() {
ExpressionEvaluatingRequestHandlerAdvice advice = new ExpressionEvaluatingRequestHandlerAdvice();
advice.setOnSuccessExpression(
"@template.remove(headers['file_remoteDirectory'] + headers['file_remoteFile'])");
advice.setPropagateEvaluationFailures(true);
return advice;
}
}
请注意,在此示例中,转换器下游的消息处理程序具有advice
在处理后删除远程文件。