草庐IT

tcp_client

全部标签

python - 如何检查是否所有数据都通过 Python 中的 TCP 套接字接收到

我正在尝试使用Python作为编程语言从TCP连接(仅限客户端)获取数据,但是,我可以看到所有数据都不是一次接收到的,而是在接收过程中被截断了……我可以在论坛上看到TCP没有以正确的顺序发送数据(有点随机),链接:Pythonsocketreceive-incomingpacketsalwayshaveadifferentsize),我错了吗?我的问题是,是否有办法确保我正确接收到所有数据?在此先感谢您的帮助和回复,PS:我已经增加了socket.recv()的缓冲区大小,但仍然面临同样的问题......而且我只在CentOS下工作编辑:(无法回答我自己的问题:(在这个论坛上还是初学者

linux - tcp 接收窗口更新

我一直在阅读有关tcp协议(protocol)及其接收窗口的latley。我还不明白的是接收方如何知道何时通告新的窗口大小?我只考虑过当接收缓冲区为0时通告一个新的窗口大小,但必须有更多的情况是接收方必须通告一个新的窗口大小,至少我是这么认为的。是否有任何标准阶段可以让接收方知道何时通告新窗口大小?我在下一个链接中检查了tcp协议(protocol)的linux实现:http://man7.org/linux/man-pages/man7/tcp.7.html但我没有发现任何关于如何知道何时公布新窗口大小的信息。谢谢你的帮助,本。 最佳答案

tcp - Netty中net.inet.tcp.recvspace、SO_RCVBUF、Direct ByteBuf和ByteBufAllocator的关系

谁能快速解释一下Netty/NIO如何从操作系统消耗TCP缓冲区?我认为TCP滑动窗口ACK由操作系统TCP堆栈(recvspace)管理,并在每个数据包(MTU大小)之后发回,直到recvspace已满。那么在NIOselector触发receive事件后,NIO(directbuf模式)创建一个directbuffer指向同一个内存区域,并标记为已读?或者它是否从recvspace复制到另一个缓冲区?如果是这种情况,那么每个应用程序的SO_RCVBUF是什么?它是否相关?我的目标是仅在完全消耗缓冲区后才从下一个缓冲区读取(并因此发送新的ACK以读取更多内容)。

Ruby - 如何使用 Ruby 将文本字符串从 TCP 服务器发送到另一台计算机上的客户端?

几天来我一直在努力学习这个,但没有任何效果。当我写这样的代码时为客户。require'socket'tcp_client=TCPSocket.new('localhost',2000)whilegrab_string=tcp_client.getsputs(grab_string)endtcp_client.close并为服务器编写这样的代码。#Setupaserverprogram.require'socket'tcp_server=TCPServer.new(2000)loop{waiting_client=tcp_server.acceptpath='C:\Users\Nil_F

bash - Debian:使用 TCP 的 Bash 电子邮件

在服务器上,我目前在使用Swiftmailer生成的日志中间歇性地收到“421意外故障,请稍后再试”。为了调试它,使用命令:openssls_client-crlf-connectwww.somesite:443我可以成功发送邮件。我想将所有谈判等放在bash脚本中,以便我重复运行它并查看是否有任何特定情况会引发421错误。我遇到过几个使用语法的例子:exec$fd"/dev/tcp/${SERVER}/${PORT}"然而,正如其他答案中所述,在构建bash时需要启用此功能,而Debian不启用此功能。除了使用此设置(我认为是--enable-net-redirections)重新编

python - 无法通过带有 SO_BINDTODEVICE 的两个 NIC 之间的 NAT 执行 TCP 握手

我正在尝试将我的计算机连接到NAT的两端(由OpenWRT运行)并通过NAT建立TCP连接:我在我的第一个NIC(eth0,ip地址129.104.0.1)上运行一个DHCP服务器,并将它连接到路由器的WAN端口(ip地址129.104.0.198)我将我的wifi(wlan0,ip地址192.168.1.119)连接到NAT后面的路由器SSID我正在使用python和SO_BINDTODEVICE选项通过NAT在服务器(在eth0上)和客户端(在wlan0上)之间发送数据包:对于服务器:self.server=socket.socket(socket.AF_INET,socket.S

tcp - Kryonet 服务器发送原始字节数组

简单的问题,是否可以用Kryonet发送原始字节数组数据包?客户端不使用Kryonet,将读取字节谢谢 最佳答案 Kryonet基于通过NIO的简单tcp通信以及内置的kryo序列化。没有kryo序列化的Kryonet只是tcp客户端/服务器,仅此而已。或者,如果您想要简单的解决方案,您可以只为具有byte[]形式的一个属性的实体创建一个包装器,然后使用客户序列化程序来序列化byte[]。这是进行某些概念验证等的最快方法。 关于tcp-Kryonet服务器发送原始字节数组,我们在Stac

networking - 我什么时候应该考虑使用 TCP 或 UDP?

我知道这两种协议(protocol)之间的区别和优缺点,虽然不是很清楚。好吧,我仍然不清楚如何使用它们,具体来说,在它们之上构建应用程序时我应该使用哪种协议(protocol)?是否存在普遍原则或普遍采用的做法?选择时应考虑哪些因素。例如。对于视频流服务,UDP始终优先于TCP。 最佳答案 TCP-当您发送信息时,您将收到express服务等确认信息。如果没有确认,则重新发送。UDP-无确认。没有重新发送。首先,您应该了解您发送和接收的信息的敏感性。例如,如果您正在处理一些汇款,您当然需要确认银行收到了您的钱,如果连接出现问题,您就

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

ios - 由于重复的 TCP SYN 而导致 TCP 连接错误

我的iPhone与Linux服务器建立了TCP连接:iOS-----tcpsyn---->linuxiOS-----tcpsyn---->linuxlinux-----tcpackwithseq=xxx--->iOSlinux-----tcpackwithseq=yyy--->iOSiOS快速重新发送TCPsyn,从而导致两个具有不同服务器序列的TCPACK。iOS使用第一个seqxxx,linux使用第二个seqyyy。所以这个连接不能传输数据。iOS如此快速地重新发送syn是一个错误,但是linux服务器在做正确的事情吗?我该如何解决? 最佳答案