c++ - TCP没有收到发送的数据

标签 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(有序关闭),但事后检查告诉我连接仍处于打开状态...我对吗?
  • 发送 block 和接收 block 之间没有系统调用(例如关闭套接字)。

我的问题是:

连接在哪里丢失以及为什么?

最佳答案

应用程序的套接字被搞乱了,问题中显示的日志不足以调试问题。

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

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

关于c++ - TCP没有收到发送的数据,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34680976/

相关文章:

c++ - 没有用于调用 FMOD::Studio::System::setListenerAttributes() 的匹配函数

C++:如果我重载 new 运算符,我是否也必须重载 delete 运算符?

linux - 如何使用 awk 只替换第二个实例一次

c - C 中的堆栈溢出代码用于编写漏洞利用程序

node.js - 运行 pm2 日志错误 SyntaxError : Unexpected token

c++ - 如何在不等待新数据到达的情况下使用 boost::asio 的 async_read_some() 读取所有可用数据?

java - Android NDK - 在 native 函数中引用 C++ 类

linux - 通过 SSH 配置 iptables 时的奇怪行为

c++ - 非阻塞套接字多线程接收模型

node.js - Socket.io 未保存在 Mongoose save() 上