我正在使用一个商业应用程序,它在消息中抛出一个 SocketException,
现有连接被远程主机强行关闭
这发生在客户端和服务器之间的套接字连接上。连接仍然有效,并且正在传输大量数据,但随后突然断开连接。
有人见过这个吗?原因可能是什么?我可以猜测一些原因,但还有什么方法可以在此代码中添加更多内容以找出原因可能是什么?
欢迎任何意见/想法。
… 最新的 …
我有一些 .NET 跟踪的日志记录,
System.Net.Sockets Verbose: 0 : [8188] Socket#30180123::Send() DateTime=2010-04-07T20:49:48.6317500Z System.Net.Sockets Error: 0 : [8188] Exception in the Socket#30180123::Send - An existing connection was forcibly closed by the remote host DateTime=2010-04-07T20:49:48.6317500Z System.Net.Sockets Verbose: 0 : [8188] Exiting Socket#30180123::Send() -> 0#0
根据日志记录的其他部分,我看到它表示0#0正在发送一个 0 字节长度的数据包。但这究竟意味着什么?
0#0
两种可能性之一正在发生,我不确定是哪一种,
连接正在关闭,但数据随后被写入套接字,从而创建了上述异常。这0#0只是意味着没有发送任何内容,因为套接字已经关闭。
连接仍然打开,并且正在发送一个零字节的数据包(即代码有错误),这0#0意味着正在尝试发送一个零字节的数据包。
你怎么看?我想这可能是不确定的,但也许其他人已经看到了这种事情?
这通常意味着远程端关闭了连接(通常通过发送 TCP/IPRST数据包)。如果您使用的是第三方应用程序,可能的原因是:
RST
第一种情况很可能就是正在发生的事情。
您可以启动Wireshark以准确查看线路上发生的情况以缩小问题范围。
如果没有更具体的信息,这里的任何人都不太可能真正帮助您。