Spring集成:failureChannel问题

时间:2016-09-28 15:31:28

标签: java spring spring-integration sftp

我使用Spring SFTP出站通道适配器通过重试机制在SFTP服务器上上传文件。如果上传错误,我会在一定次数的重试后发送电子邮件并将文件移动到错误文件夹。

以下是我的配置。

<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日志:spring-integration.logs

1 个答案:

答案 0 :(得分:1)

根据您的日志,我们有来自源目录的两个文件:

2016-09-28 22:14:34,595 [DEBUG] [org.springframework.integration.file.FileReadingMessageSource] Added to queue: [D:\CSVFiles\MyCustomerTarget_20160928221429.csv, D:\CSVFiles\MyOrderTarget_20160928221429.csv]

也许这会让你感到困惑,因为他们两个都用相同的后缀完成了?

这两个文件都无法传输到FTP,因此有两个关于错误的电子邮件。每个文件一个。

根据您的日志不再发送额外的电子邮件。

  

不,我为每个文件收到了2封邮件。因此,共有4个邮件,因为有2个文件。

好了,让我们再看一下你的配置吧!

<int-mail:to value="${fail.email.to}" />
<int-mail:cc value="${fail.email.to}" />

这并不能通过GMail向我发送两份副本,但这并不意味着其他邮件服务器不会将两封电子邮件传递给同一收件人。