处理套接字断开.Boost / Winsock

Handling socket disconnection. Boost / Winsock

本文关键字:Winsock Boost 断开 套接字 处理      更新时间:2023-10-16

正如标题所示,我使用过winsock &提高套接字。我有一个难以置信的困难检测断开。

首先,我知道可以通过以下命令发现断开连接:

  1. recv()/async_read()返回socket错误或0。
  2. send()/async_write() ... ... ...
  3. 客户端是否手动关闭,被中断/程序关闭-等等。

问题场景如下:

我使用closesocket()关闭连接。客户端检测到断开连接-一切正常

我关闭程序-有50/50的机会客户端无法检测到断开连接。由于某些原因,我的IO重叠WSARecv()不能保证检测。

我终止进程。检测的几率增加到80%。But for the rest of the 20% - here's what's bothering me. I implemented a keep-alive ping mechanism which sends data to the server. Even if I killed the program - the server is still async_writing() to the connection - even though it's not detected or dead.

这是我必须忍受的吗?我有点迷路了,因为我已经尽我所能去检测断线了……然而,他们仍然是一个问题。

TCP不能保证仅接收的一方能够检测到连接丢失。您在TCP之上实现的协议应该在其设计中考虑到这一点。如果没有,协议就被打破了,你应该大声地向设计它的人投诉。

如果你自己设计一个协议,不要跳过记录协议的步骤。这应该始终包括它是否支持应用程序级消息、它们是如何形成帧的、谁在何时传输、如何检测断开连接、任何超时等等。在没有实际设计的情况下实现的"即兴"协议基本上注定要失败,即使它碰巧工作,也永远无法维护,因为它实际上不可能确定它应该如何工作。

一旦有了协议规范,至少可以通过以下简单步骤来确定问题所在:

  1. 服务器是否遵循规范?如果不是,停下来。

  2. 客户是否遵循规范?如果不是,停下来。

  3. 停止。

没有说明,这些问题是无法回答的。很多痛苦都是这样造成的。