骆驼SFTP路由继续失败



我有一个相当简单的路线

sftp://hostname:22//incoming/folder/location/?username=username&password=xxxxx
&localWorkDirectory=/tmp&readLock=changed&readLockCheckInterval=2000
&move=processed/$simple{date:now:yyyy}/$simple{date:now:MM}/$simple{date:now:dd}${file:name}
&consumer.delay=450000&stepwise=false&streamDownload=true&disconnect=true

我还有一个onException子句

onException(ValidationException.class)
            .handled(true)
            .logStackTrace(true)
            .filter(header("VALIDATION_ERROR").isEqualTo(true))
            .choice()
              .when(header("CamelFileName").contains("Param1"))
               .to(sftp://hostname:22//One/error/folder?password=xxxxxx&username=username)
              .when(header("CamelFileName").contains("Param2"))             
               .to(sftp://hostname:22//Two/error/folder?password=xxxxxx&username=username)
            .endChoice();

当我有单个文件时,路由似乎按预期工作。当多个文件和异常发生时,我得到许多不同的异常,如

org.apache.camel.component.file.GenericFileOperationFailedException: Cannot list directory: incoming/folder/location
Caused by: java.lang.IndexOutOfBoundsException

我尝试使用路由中提到的所有属性,即streamDownload, stepwise, readLock, localWorkDirectory等。但是,多个文件时的错误处理不工作。我看到第一个文件正在处理。然而,一旦异常发生,它不会移动到已处理的文件夹,然后incoming/folder/location变得不可列。我尝试使用继续(true),而不是处理(true)

问题是在同一个交换中处理多个文件。在例外情况下,路由试图通过FTP备份同一服务器上的错误文件。解决方案是将正文拆分为多个交换器,这样每个文件都有自己的交换器,并单独处理它们。

from(sftp://hostname:22//incoming/folder/location/?username=username&password=xxxxx
&localWorkDirectory=/tmp&readLock=changed&disconnect=true&stepwise=false
&move=processed/$simple{date:now:yyyy}/$simple{date:now:MM}/$simple{date:now:dd}${file:name}
&consumer.delay=450000).split(body()).processRef("incomingProcessor").end();

相关内容

  • 没有找到相关文章