具有一个spring集成应用程序,其中使用s3-outbound-channel-adapter将文件从文件夹路由到S3存储桶。如果文件处理成功,则文件将被移至相应的目标存储桶。如果有任何错误,文件将通过错误通道移至错误存储区。
必须在包含以下详细信息的文本文件中生成每日统计报告。
已处理的文件总数: 完全成功: 总错误:
想知道如何不成功/错误地处理文件。有什么办法可以达到这个要求。
任何建议或示例都会有所帮助。
通过文档中的DefaultMessageChannelMetrics和Micrometer集成进行了操作。不确定是否可以满足我的要求。
具有单独的网关和适配器来处理成功和错误文件。
成功:
<int-aws:s3-outbound-gateway id="s3FileMover"
request-channel="filesOutS3GateWay"
reply-channel="filesOutS3ChainChannel"
transfer-manager="transferManager"
bucket-expression = "headers.TARGET_PATH"
key-expression="headers.file_name"
command="UPLOAD">
<int-aws:request-handler-advice-chain>
<ref bean="retryAdvice" />
</int-aws:request-handler-advice-chain>
</int-aws:s3-outbound-gateway>
错误:
<int-aws:s3-outbound-channel-adapter id="filesErrorS3Mover"
channel="filesErrorS3MoverChannel"
transfer-manager="transferManager"
bucket="${aws.s3.error.bucket}"
key-expression="headers.TARGET + '/' + headers.file_name"
upload-metadata-provider = "fileMetaDataProvider"
command="UPLOAD">
<int-aws:request-handler-advice-chain>
<bean class="org.springframework.integration.handler.advice.ExpressionEvaluatingRequestHandlerAdvice">
<property name="onSuccessExpressionString" value="payload.delete()"/>
</bean>
</int-aws:request-handler-advice-chain>
答案 0 :(得分:1)
您可以直接在消息通道上直接查询和重置MessageChannelMetrics
。
getSendCount();
reset();
所有标准消息通道均实现该接口,因此只需注入该通道即可。
@Autowired
private MessageChannelMetrics filesOutS3GateWay;
private int getCount() {
return this.filesOutS3GateWay.getSendCount();
}