我有一个配置类,它不断地轮询我的 FTP 目录。奇怪的行为是 SftpPersistentAcceptOnceFileListFilter 立即将文件保存在元数据存储表中,但不会立即被作业启动器拾取以进行处理。我必须手动从元数据存储表中删除该条目 3-4 次,然后文件被拾取。是代码问题还是 FTP 服务器问题?想不通。。
知道我是否遗漏了什么?
@Bean
public IntegrationFlow sftpInboundNocFlow(FileNocMessageToJobRequest fileNocMessageToJobRequest) throws Exception {
return IntegrationFlows
.from(s -> s.sftp(this.sftpConfig.sftpSessionFactory())
.filter(this.sftpPersistantNocFilter())
.preserveTimestamp(true)
.remoteDirectory(this.sftpProperties.getRemoteOutboundDirectoryNoc())
.deleteRemoteFiles(this.sftpProperties.isDeleteRemoteFilesEnabled())
.autoCreateLocalDirectory(true)
.localDirectory(new File(FileUtils.getTempDirectoryPath() + this.sftpProperties.getLocalInboundDirectoryNoc())),
e -> e.id("sftpInboundNocAdapter")
.autoStartup(true)
.poller(Pollers.fixedDelay(9000)))
.handle(fileNocMessageToJobRequest)
.handle(this.jobNocLaunchingGateway())
.log(LoggingHandler.Level.WARN, ">>>>>>>>>>headers.id + ': ' + payload")
.channel("nullChannel")
.get();
}
@Bean
public CompositeFileListFilter sftpPersistantNocFilter() {
log.info("sftpPersistantNocFilter is called");
CompositeFileListFilter nocfilters = new CompositeFileListFilter();
nocfilters.addFilter(new SftpPersistentAcceptOnceFileListFilter(this.metadataStore(),"Downloaded_File:"));
nocfilters.addFilter(new SftpRegexPatternFileListFilter(".*\\bNOC\\b.*"));
// nocfilters.addFilter(new SftpSimplePatternFileListFilter("*.csv"));
return nocfilters;
}