我们正在使用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
答案 0 :(得分:0)
我认为您应该确保您的客户端和服务器同意(de)序列化协议。有关详细信息,请参阅Reference Manual:
TCP是一种流媒体协议;这意味着必须为通过TCP传输的数据提供一些结构,因此接收器可以将数据划分为离散消息。连接工厂配置为使用(反)序列化器在消息有效负载和通过TCP发送的位之间进行转换。
默认值为ByteArrayCrLfSerializer
,用于处理\r\n
邮件分隔符。
因此,您的客户可能会收到该软件包,但由于它没有符合正确的分隔符,因此无法等待回复。
答案 1 :(得分:0)
java.net.SocketException:连接重置
表示服务器出于某种原因强制套接字关闭(RST
)。您需要查看服务器日志。
也许它不期望默认的有线格式(文字以CRLF
- 0x0d0a
终止)。