我有一个相当简单的路线
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();