spring集成tcp-out-bound异常

时间:2017-09-29 08:36:34

标签: java spring tcp spring-integration tcpclient

我们正在使用Spring集成4.1.3。

使用tcp-outbound-gateway实现客户端。

在请求期间从服务器收到了tcp rset数据包,并发生了异常。 是什么原因? 谢谢。

    // interface
    public interface TcpSendGateway {
        public byte[] send(String text);
    } 
    // send
    byte[] response = sendGateway.send(request);




    <int:gateway id="gw"
                 service-interface="com.mainpay.service.TcpSendGateway"
                 default-request-channel="input"
                 default-reply-channel="reply"/>

    <int-tcp:tcp-connection-factory id="client"
                                    type="client"
                                    host="#{prop['app.cultureland.host']}"
                                    port="#{prop['app.cultureland.port']}"
                                    so-timeout="10000"
                                    single-use="false"
                                    so-keep-alive="true"
    />                         
    <int:channel id="input" />
    <int-tcp:tcp-outbound-gateway id="outGateway" 
                                  request-channel="input"
                                  reply-channel="reply"
                                  connection-factory="client"
                                  request-timeout="10000"                                      
                                  reply-timeout="10000"                                                                                                               
                                  />        
    <int:channel id="reply" datatype="java.lang.String" />

错误日志

▶ 17.09.29 17:07:37 [pool-2-thread-2] ERROR o.s.i.i.t.c.TcpNetConnection - Read exception 211.59.10.133:7611:51503:d2ec0199-fd15-49c0-bd99-0d864eb2145b SocketException:Connection reset
▶ 17.09.29 17:07:39 [http-nio-19900-exec-5] ERROR o.s.i.ip.tcp.TcpOutboundGateway - Tcp Gateway exception
org.springframework.messaging.MessagingException: Exception while awaiting reply; nested exception is java.net.SocketException: Connection reset
    at org.springframework.integration.ip.tcp.TcpOutboundGateway$AsyncReply.getReply(TcpOutboundGateway.java:288)

wireshark日志 enter image description here

2 个答案:

答案 0 :(得分:0)

我认为您应该确保您的客户端和服务器同意(de)序列化协议。有关详细信息,请参阅Reference Manual

  

TCP是一种流媒体协议;这意味着必须为通过TCP传输的数据提供一些结构,因此接收器可以将数据划分为离散消息。连接工厂配置为使用(反)序列化器在消息有效负载和通过TCP发送的位之间进行转换。

默认值为ByteArrayCrLfSerializer,用于处理\r\n邮件分隔符。

因此,您的客户可能会收到该软件包,但由于它没有符合正确的分隔符,因此无法等待回复。

答案 1 :(得分:0)

  

java.net.SocketException:连接重置

表示服务器出于某种原因强制套接字关闭(RST)。您需要查看服务器日志。

也许它不期望默认的有线格式(文字以CRLF - 0x0d0a终止)。