TCP不接收发送的数据
TCP does not receive sent data
我一直在测试一个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(有序关闭),但事后检查告诉我连接仍然打开。。。我说得对吗
- 发送块和接收块之间没有系统调用(例如关闭套接字)
我的问题是:
连接在哪里丢失,为什么?
应用程序的套接字被搞砸了,问题中显示的日志不足以调试问题。
使用wireshark捕获数据有助于发现问题:应用程序重复套接字,由于逻辑问题,客户端使用错误的套接字进行传输。
感谢您的提示:帮助我们改进了代码。
相关文章:
- 防止主数据类型C++的隐式转换
- 用于访问容器<T>数据成员的正确 API
- 嵌套在类中时无法设置成员数据
- 使用流处理接收到的数据
- 静态数据成员的问题-修复链接错误会导致编译器错误
- 处理小于cpu数据总线的数据类型.(c++转换为机器代码)
- 在cuda线程之间共享大量常量数据
- C++将文本文件中的数据读取到结构数组中
- 如何在C++中序列化结构数据
- 在C++中打印指向不同基元数据类型的指针的内存地址
- 通过套接字[TCP]传输数据 如何在C / C ++中打包多个整数并使用send() recv()传输数据
- 在c代码之间共享数据的最佳方式
- 链表,反向函数,数据结构
- 数据成员SFINAE的C++17测试:gcc vs clang
- C++浮点数据类型和字符串数据类型无法子到模板函数中
- 如何对点云数据进行排序
- 从矢量<无符号字符>转换为字符* 包括垃圾数据
- 尝试通过OCI例程从Oracle获取blob数据,但出现错误:ORA-01008:并非所有变量都绑定
- Cuda C++:设备上的Malloc类,并用来自主机的数据填充它
- 在运行时处理类型擦除的数据-如何不重新发明轮子