我使用套接字在C#.NET中有一个客户端服务器应用程序写入程序。
我经常收到日志消息(比如说每小时大约4条消息),这条消息,
An existing connection was forcibly closed by the remote host
在这种情况下,错误发生在“服务器”端。
我决定使用wireshark来分析发生的事情,我明白了。没有延迟,这一切都会在几秒钟内发生。
Server > Client [PSH, ACK] Seq=55653 Ack=4472 Win=63940 Len=148
Client > Server [ACK] Seq=4472 Ack=55801 Win=4038 Len=0
Server > Client [PSH, ACK] Seq=55801 Ack=4472 Win=63940 Len=148
Client > Server [ACK] Seq=4472 Ack=55949 Win=4001 Len=0
Server > Client [PSH, ACK] Seq=55949 Ack=4472 Win=63940 Len=142
Client > Server [PSH, ACK] Seq=4472 Ack=55949 Win=4001 Len=31
Client > Server [RST, ACK] Seq=4503 Ack=55949 Win=0 Len=0
因此客户端和服务器之间正在发送内容(PSH)和确认内容(ACK)。 RST突然发生了。这根据维基百科是一个重置,这个重置对应于我上面的'现有连接被强行...'消息。
这究竟意味着什么?这是否意味着重置会导致问题?我认为答案是否定的,更有意义的是重置是问题的结果?即服务器端的套接字由于某种原因而死,客户端将重置发送到服务器尝试将其唤醒。
思想?
答案 0 :(得分:1)
有时行为不端的客户端会获取或发送它想要的内容,然后立即退出(关闭套接字,然后突然切断连接)。偶尔看到任何暴露在互联网上的服务都是正常的。
如果是你自己的代码造成这种情况,请确保发送任何“我现在完成”命令(常见的是“退出”),并在关闭之前正确“关闭”连接。除此之外,关于你应该造成的唯一重置将涉及你的互联网访问剥落。
答案 1 :(得分:0)
服务器和客户端都是您自己的代码。即使我遇到了类似的问题,但在我的情况下,服务器不是我的代码,所以我无法找到客户端关闭连接并发送PSH和RST消息的原因。
在任何一种情况下,如果你得到的错误就像你得到的那样,那么就可以创建一个新套接字并建立通信。