私は、再試行メカニズムを使用してSFTPサーバー上にファイルをアップロードするためにSpring SFTPアウトバウンドチャネルアダプタを使用しています。アップロードでエラーが発生した場合は、メールを送信し、特定の回数の再試行後にファイルをエラーフォルダに移動しています。Spring統合:failureChannelの問題
以下は私の設定です。
<file:inbound-channel-adapter id="csvFileChannel"
directory="${csv.base.directory}" filename-regex="^(.*).csv"
comparator="lastModifiedComparator" prevent-duplicates="true">
<int:poller fixed-rate="5000" />
</file:inbound-channel-adapter>
<bean id="lastModifiedComparator"
class="org.apache.commons.io.comparator.LastModifiedFileComparator" />
<bean id="sftpSessionFactory"
class="org.springframework.integration.sftp.session.DefaultSftpSessionFactory"
lazy-init="true">
<property name="host" value="${sftp.host}" />
<property name="port" value="${sftp.port}" />
<property name="user" value="${sftp.user}" />
<property name="password" value="${sftp.password}" />
</bean>
<int-sftp:outbound-channel-adapter
id="sftpOutboundAdapter" session-factory="sftpSessionFactory" channel="csvFileChannel"
remote-file-separator="/" remote-filename-generator-expression="payload.getName()"
remote-directory="/" mode="REPLACE">
<int-sftp:request-handler-advice-chain>
<bean
class="org.springframework.integration.handler.advice.ExpressionEvaluatingRequestHandlerAdvice">
<property name="onSuccessExpression"
value="payload.renameTo(new java.io.File('${csv.archive.directory}' , payload.name))" />
<property name="successChannel" ref="nullChannel" />
<property name="onFailureExpression"
value="payload.renameTo(new java.io.File('${csv.error.directory}' , payload.name))" />
<property name="failureChannel" ref="failChannel" />
<property name="trapException" value="true" />
</bean>
<ref bean="retryAdvice" />
</int-sftp:request-handler-advice-chain>
</int-sftp:outbound-channel-adapter>
<int:handler-retry-advice id="retryAdvice"
max-attempts="5">
<int:fixed-back-off interval="5000" />
</int:handler-retry-advice>
<int:channel id="failChannel" />
<int:chain input-channel="failChannel" output-channel="mailMessageChannel">
<int:transformer
expression="'SFTP Upload failed for the file: ' + payload.failedMessage.payload.name " />
</int:chain>
<bean id="mailSender" class="org.springframework.mail.javamail.JavaMailSenderImpl">
<property name="host" value="${smtp.host}" />
<property name="port" value="${smtp.port}" />
<property name="username" value="${smtp.userName}" />
<property name="password" value="${smtp.password}" />
<property name="javaMailProperties">
<props>
<prop key="mail.smtp.auth">true</prop>
</props>
</property>
</bean>
<int:channel id="mailMessageChannel" />
<int:chain input-channel="mailMessageChannel">
<int-mail:header-enricher>
<int-mail:to value="${fail.email.to}" />
<int-mail:cc value="${fail.email.to}" />
<int-mail:from value="${fail.email.to}" />
<int-mail:subject value="SFTP Upload failed" />
</int-mail:header-enricher>
<int-mail:outbound-channel-adapter
mail-sender="mailSender" />
</int:chain>
私が直面している問題は、各ファイルに対して2つの電子メールが届いていることです。問題を把握することはできません。 spring-integration.logs
'org.springframework.integration'カテゴリの' DEBUG'ログを共有してください。 'retryAdvice'なしでどれくらいのメールを受信しますか? –
@ArtemBilan:スプリング統合ログのリンクを提供しました。 'retryAdvice'なしで試してみると2つのメールが届きました、 – Vinod