草庐IT

recv-Buffer

全部标签

Linux TCP : high Send-Q on sender, 接收器上的 Recv-Q 为零

怎么会这样:两台机器之间有一个TCP套接字在一些成功的双向通信之后,发送方应用程序卡在写入套接字和接收方读取套接字netstat报告发送方套接字的高Send-Q(几兆字节)(即使等待几个小时后该值也没有改变)netstat报告接收器上套接字的Recv-Q为零tcpdump报告套接字上的唯一事件是周期性(每两分钟)ACK没有来自发送方的数据和立即ACK响应没有来自接收方的数据为什么发送方机器不尝试将排队的数据发送到接收方? 最佳答案 我的情况是,客户端以8KB的block写入数据,服务器试图读取8KB,然后服务器会将其写入RAID0磁

python - Python TCP 套接字 recv(1) 与 recv(n) 的效率

我正在构建一个TCP应用程序,它使用换行符\n来分隔未知长度(但通常​​小于64字节)的消息。我正在寻找thisarticle非常有用。是一次recv一个字符并检查它是否为换行符或recv更大缓冲区并存储“剩余字符”的最佳(即最有效/最快)方法"在类里面?一次一个def__recv_until_newline(self):message=""whileTrue:chunk=self.socket.recv(1)ifchunk==""orchunk=="\n":breakmessage+=chunkreturnmessage保持缓冲区def__recv_until_newline(sel

c++ - 如何在不使用 QTcpSockets 的情况下在 Qt 中创建插槽并将其连接到 TCP recv()?

我想在Qt中或在C++中为TCP中的recv()函数创建一个插槽,以便当套接字接收到数据时它会自动调用该插槽,我可以使用QTcpSockets来完成,但我不能'由于某些限制,我没有使用它们。目前我正在使用计时器从recv()函数接收数据。请指引我正确的方向。tcp.hifndefTCP_H#defineTCP_H#pragmaonce#include#include#include#include"config.h"#include"tcp_packets.h"#include"change_ending.h"#include"md5.h"#pragmacomment(lib,"Ws2

sockets - socket recv() 是否强制刷新 socket send() 缓冲区?

在我的应用程序中,我向服务器发送了两条小消息(类似memcached的服务)。在类似Python的伪代码中,这看起来像:sock.send("addsome-key0")ignored=sock.recv(...)sock.send("incrsome-key1")new_value=sock.recv(...)由于服务器支持即发即弃式写入,我可以优化此代码使其看起来更像:sock.send("addsome-key0noreply")sock.send("incrsome-key1")new_value=sock.recv(...)但是,这需要更长的时间——此版本平均需要40毫秒,而

winsock - TCP IP recv() 函数未接收到来自服务器的回显消息

我在Windows中使用TCPIP套接字程序,我在其中创建了一个客户端用于将数据传输到服务器和服务器正在将消息回显给客户端(请注意,服务器已通过telnet应用程序正常工作)。但是当我从客户端发送测试消息时,它会在服务器端收到,但是当我试图在客户端中读取回显消息时>使用recv()函数的一侧我没有得到回显消息,但是无论我在服务器侧输入什么,它都会显示在客户端侧接收recv()函数我通过此链接关注程序http://cs.baylor.edu/~donahoo/practical/CSockets/code/TCPEchoClientWS.c有人有什么解决办法吗?

c - 使用 TCP/IP : recv() blocks 的套接字编程

我正在开发一个简单的客户端/服务器项目,它将一大块数据从客户端移动到服务器。我使用TCP/IP。服务器设置监听套接字,客户端连接。首先传输一个短的16字节“header”,其中包含一些信息,包括之后要传输的数据量。然后传输大块(大约2MB),即send(socketDesc,(void*)myBuffer,bigChunkSize,0);和recv(socketDescPeer,(void*)myBuffer,bigChunkSize,0)首先,我使用winsock2在Windows下实现了客户端,它可以正常工作。我现在尝试将此实现移植到linux,在这种情况下,服务器端永远不会从re

python - socket.recv() 什么时候引发异常?

我正在使用阻塞套接字,我对recv()很困惑,因为我没有找到任何关于它的合适文档。官方的似乎仅限于我。另一件让我感到困惑的事情是互联网上的人(以及这个网站上的人)说它不会引发任何阻塞套接字的异常,但它只是一直在等待。如果我粗暴地关闭服务器,它会抛出Errno10054(socket.error)。 最佳答案 简单来说,recv会在底层socket操作失败时抛出异常。问题在于它取决于您所使用的操作系统。在这里我可以猜到你在Windows上,因为10054是一个Windowserrorcode用于连接重置。幸运的是,套接字操作失败的时间

c - recv 阻塞直到发送第二个数据包

我正在使用recv方法在WindowsCE6.1系统上通过TCP接收数据。出于某种原因,第一次调用recv有时会阻塞,直到发送下一个数据包。我现在突然同时收到两个数据包。tcpClientSocketId=accept(tcpServerSocketId,(structsockaddr*)&client,(int*)&sockaddrLength);if(tcpClientSocketId我验证了数据实际上是使用Wireshark发送的。有人知道为什么recv方法会阻塞吗?编辑:只是为了澄清:我不依赖于逐个数据包接收的数据——这些数据被组合成一个字符串,然后进行处理。除了等待recv调

c - TCP 连接错误 "No buffer space available"

我在非常大规模(2048台机器)上测试自制分布式键值存储时遇到此错误,它在1024台机器上运行良好。通信模式是n:n,这意味着每台机器向其他机器发送大量请求。我使用CTCP套接字来实现它,SO_REUSEADDR来回收那些套接字。任何人都可以给我一些关于可能导致此错误的可能性的提示吗?代码很复杂,很难在不丢失必要逻辑的情况下将其简化并发布在这里。所以我只想知道所有可能的原因才开始调试。顺便说一句,我将设置更改为:echo8000>/proc/sys/kernel/threads-maxecho8000>/proc/sys/net/core/somaxconn#监听队列的限制,默认为12

windows - 套接字编程更新 : recv returning -1, 错误 = 10053

我正在Windows7上实现一个围绕套接字recv()调用循环的TCP/IP应用程序。对于少量数据(20MB),recv在两者之间失败。详细信息:我的应用程序需要与运行的HTTP服务器进行通信,两者都在同一台机器上运行,在这种情况下,tcp应用程序正在向HTTP服务器发送大量数据它给出错误=2,recv返回0。错误2表示ENOENT,但它是什么意思?。有谁知道这是什么(关于套接字)以及我如何解决这个问题?msgLen=recv(s,msg,BUFFER_SIZE,0);if(msgLen>0){//doprocessing}else{printf("\nnodatareceived..