TCP无法接收已发送的数据

时间:2016-01-08 15:52:46

标签: c++ linux sockets tcp recv

我一直在测试TCP客户端/监听器。

我的测试打开10个客户端并正确接受它们。然后它通过每个数据发送一些数据。只有在正确发送所有数据后,它才会尝试在对方接收它。

在这里,您可以看到前4个连接的 strace 的输出。 getpeername()用于在每次发送接收之后检查每一侧的连接。我已经尝试在循环中执行接收,直到它获得无效的内容。为清楚起见,我在每个连接中显示单个 recv 的结果。

send(4, "abcdefghij", 10, 0)            = 10
getpeername(4, {sa_family=AF_INET, sin_port=htons(1366), sin_addr=inet_addr("127.0.0.1")}, [16]) = 0
getpeername(5, {sa_family=AF_INET, sin_port=htons(44847), sin_addr=inet_addr("127.0.0.1")}, [16]) = 0
send(6, "abcdefghij", 10, 0)            = 10
getpeername(6, {sa_family=AF_INET, sin_port=htons(1366), sin_addr=inet_addr("127.0.0.1")}, [16]) = 0
getpeername(7, {sa_family=AF_INET, sin_port=htons(44848), sin_addr=inet_addr("127.0.0.1")}, [16]) = 0
send(8, "abcdefghij", 10, 0)            = 10
getpeername(8, {sa_family=AF_INET, sin_port=htons(1366), sin_addr=inet_addr("127.0.0.1")}, [16]) = 0
getpeername(9, {sa_family=AF_INET, sin_port=htons(44849), sin_addr=inet_addr("127.0.0.1")}, [16]) = 0
send(10, "abcdefghij", 10, 0)           = 10
getpeername(10, {sa_family=AF_INET, sin_port=htons(1366), sin_addr=inet_addr("127.0.0.1")}, [16]) = 0
getpeername(11, {sa_family=AF_INET, sin_port=htons(44850), sin_addr=inet_addr("127.0.0.1")}, [16]) = 0
[...]
recv(5, "", 10, 0)                      = 0
getpeername(4, {sa_family=AF_INET, sin_port=htons(1366), sin_addr=inet_addr("127.0.0.1")}, [16]) = 0
getpeername(5, {sa_family=AF_INET, sin_port=htons(44847), sin_addr=inet_addr("127.0.0.1")}, [16]) = 0
recv(7, "abcdefghij", 10, 0)            = 10
getpeername(6, {sa_family=AF_INET, sin_port=htons(1366), sin_addr=inet_addr("127.0.0.1")}, [16]) = 0
getpeername(7, {sa_family=AF_INET, sin_port=htons(44848), sin_addr=inet_addr("127.0.0.1")}, [16]) = 0
recv(9, "", 10, 0)                      = 0
getpeername(8, {sa_family=AF_INET, sin_port=htons(1366), sin_addr=inet_addr("127.0.0.1")}, [16]) = 0
getpeername(9, {sa_family=AF_INET, sin_port=htons(44849), sin_addr=inet_addr("127.0.0.1")}, [16]) = 0
recv(11, "abcdefghij", 10, 0)           = 10
getpeername(10, {sa_family=AF_INET, sin_port=htons(1366), sin_addr=inet_addr("127.0.0.1")}, [16]) = 0
getpeername(11, {sa_family=AF_INET, sin_port=htons(44850), sin_addr=inet_addr("127.0.0.1")}, [16]) = 0
[...]

注意:

  • 发送消息的接收仅在偶数连接(客户端0,客户端2,客户端4 ......)上发生。
  • 每个连接都使用阻塞套接字,因此recv()应该永远等待。
  • 连接失败返回0(有序关机),但经过检查后告诉我连接仍然打开......我是否正确?
  • 发送阻止和接收阻止之间有无系统调用(例如关闭套接字)。

我的问题是:

连接丢失的原因和原因?

1 个答案:

答案 0 :(得分:0)

套接字与应用程序混淆,问题中显示的日志不足以调试问题。

使用wire shark捕获数据有助于发现问题:应用程序重复套接字,并且由于逻辑问题,客户端使用错误的传输。

感谢您提示:帮助我们改进了代码。