gpt4 book ai didi

java - 如果在路由完成后移动文件失败,让 Apache Camel 停止重试

转载 作者:行者123 更新时间:2023-11-30 08:50:24 25 4
gpt4 key购买 nike

下面的示例路由获取一个文件并对它们执行一系列操作。完成后,如 camel:from 字段中所述,路由将被指示将文件移动到 .processed 目录。或者,如果失败,将其移至 .error 文件夹。

当另一个进程锁定文件(即 excel)并且 camel 无法移动文件时,就会出现问题,因此,它会无限地重试,这是一种不受欢迎的行为。

添加 retrypolicyonException 不会解决这个特定问题,因为我不想重试整个路由而是重试文件只移动

<camel:route id="aRoute">
<camel:from
uri="file://{{sourceFileLocation}}?include=fileToProcess.csv&amp;moveFailed=.error/$simple{date:now:yyyy}/$simple{date:now:MM}/$simple{date:now:dd}/$simple{file:name}&amp;move=.processed/$simple{date:now:yyyy}/$simple{date:now:MM}/$simple{date:now:dd}/$simple{file:name}"/>
<camel:setHeader headerName="CATEGORY">
<camel:constant>category a</camel:constant>
</camel:setHeader>
<camel:process ref="asOfDateService"/>
<camel:process ref="batchIdService"/>
<camel:process ref="aService"/>
<camel:to uri="log:aRoute"/>
<camel:process ref="factXLookup"/>
<camel:process ref="factXConversionInsert"/>
<camel:process ref="batchTableCleanupService"/>
<camel:process ref="batchUpdateService"/>
<camel:onException>
<camel:exception>java.lang.Exception</camel:exception>
<camel:process ref="batchFailedService"/>
</camel:onException>
</camel:route>

为了清楚起见,您可以忽略上面的 onException,因为它处理的是流程的数据完整性/质量问题。

TLDR:如何在不重新执行整个路由的情况下重试 camel 的文件移动?

最佳答案

这是 File 组件需要处理的事情,而不是您的路由。

您可以使用 readLock 选项(以及其他相关选项)配置文件组件处理锁定文件的方式。该选项在 File2 component documentation page 上有广泛的描述

关于java - 如果在路由完成后移动文件失败,让 Apache Camel 停止重试,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30998764/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com