草庐IT

Read-Only

全部标签

Java 对象 LinkedList 属性 : only receiving the first element on server-side using TCP

一些上下文:客户端正在向服务器发送一个SOSPFPacket对象(通过TCP),该对象具有各种属性,例如VectorlsaArray.LSA本身有一个LinkedListlinks属性。在我的测试用例中,发送了两条消息。在这两封邮件中,只有一个LSA在vector中。在第一条消息中,LSA有一个LinkDescription,在第二条消息中,它有两个。当我发送消息时,我会增加messageId.服务器收到两条消息都带有正确的id,但在第二条消息中,链接只包含一个链接而不是两个。我是无知的...对象实现如下:importjava.io.*;importjava.util.Vector;p

c++ - boost::asio 在 async_read 中复制输入数据

最近从libevent转成boost::asio,一周后发现一个奇怪的现象:当我从客户端读取数据时,有些数据好像是重复的,好像库没有'不必将其标记为已读(或类似的东西)。我的“读取”方法如下所示:voidclient::doRead(){deletereadBuffer;//gettingridofolddatareadBuffer=newSerializedBuffer((uint)READ_BUFFER_SIZE);readBuffer->position(0);asio::async_read(socket,asio::buffer(readBuffer->bytes(),REA

c++ - boost read()永远不会返回,即使在服务器(ssl)boost上执行了写入

我有一个异步运行的服务器和一个同步运行的客户端。客户端和服务器进行握手,然后进行SSL握手。客户端向服务器发送消息,服务器读取消息(我可以正确打印出来),然后服务器发回响应boost::async_write。响应离开服务器,读取在客户端boost::read()上执行,但客户端永远不会从读取命令返回。最终请求超时并抛出异常(requesttimedout)。服务端是异步的,客户端是同步的。请注意,在没有SSL的情况下,一切正常,但在使用SSL的情况下,上述情况就会出现。我在Wireshark中看到握手工作正常并且SSL和TCP握手都是正确的。此外,当客户端发送第一条消息boost::

sockets - POSIX TCP 套接字上的保持事件失败是否会导致挂起的 read() 返回?

给定以下事件序列:read()在启用了保持事件且没有可用数据的POSIXTCP套接字上执行。keep-alive机制决定连接断开。假设SIGPIPE被忽略,read()会返回吗? 最佳答案 它将返回-1和errno==ECONNRESET。 关于sockets-POSIXTCP套接字上的保持事件失败是否会导致挂起的read()返回?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/

c# - NetworkStream:ReadTimeout 及其效果 Read()

我对如何使用ReadTimeout以及它如何影响Read()感到困惑。当尝试读取网络流时,有3种情况,假设我们正在尝试读取X个字节:数据可用,字节数据可用,bytes=X数据可用,字节数>X没有可用数据,ReadTimeout>0没有可用数据,ReadTimeout=0文档有点模棱两可,没有明确提及Read()调用中的ReadTimeout,或者ReadTimeout是否影响Read()调用。Thismethodreadsdataintothebufferparameterandreturnsthenumberofbytessuccessfullyread.Ifnodataisavai

node.js - Node : TCP socket server only returns data the first time

我正在尝试在node.js中编写一个小型中继脚本,用于监听本地套接字上传入的TCP连接,并在获得连接时将流量转发给第3方。它还必须从第3方获取任何返回的数据并将其发送回原始本地套接字。我试过像http://delog.wordpress.com/2011/07/19/a-tcp-relay-mechanism-with-node-js/这样的代码它确实有效,但它要求发送者是一个正在监听套接字本身的服务器,我的实用程序旨在与任何试图创建出站TCP连接的程序一起使用。不幸的是,我遇到的问题是第一次一切都很好,客户端将数据发送到“路由器”程序,路由器将其转发到另一台服务器,然后从客户端返回数

c - Linux TCP/IP 诊断为什么在 C 程序中 TCP/IP read() 返回 0

我有许多C程序在Linux主机(RHEL6.6)上运行。它们与同一主机上的其他应用程序有TCP/IP连接。每个连接上的流量很少。每隔一段时间,对同一主机上进程的其中一个套接字的read()调用会返回0。这些套接字通常在应用程序的生命周期内保持不变,因此它们在正常操作期间不会完全关闭。我希望如果发生错误,例如另一端崩溃,read()将返回-1并设置errno。所以,问题是-除了TCP/IP连接被另一端彻底关闭(shutdown(fd);close(fd))之外,是否还有其他原因会导致read()调用返回0?read()的手册页指出仅在EOF时返回0,而recv()手册页指出它返回“当对等

asynchronous - 我如何 read_until future 链中的 tokio::net::TcpStream?

我想从TcpStream读取数据,直到遇到“\0”。问题是tokio::io::read_until需要流为BufRead。fnpoll(&mutself)->Poll{matchself.listener.poll_accept()?{Async::Ready((stream,_addr))=>{lettask=tokio::io::read_until(stream,0,vec![0u8;buffer]).map_err(|_|...).map(|_|...);tokio::spawn(task);}Async::NotReady=>returnOk(Async::NotReady

c# - TCP 套接字错误 : Only one usage of each socket address (protocol/network address/port) is normally permitted

我正在开发一个小型TCP客户端/服务器库。我在创建客户端并将其连接到服务器时遇到了这个问题。它给了我这个异常(exception)每个套接字地址(协议(protocol)/网络地址/端口)通常只允许使用一次我的代码是。publicTCPClient(stringremoteIPAddress,intport){this.remoteIPAddress=IPAddress.Parse(remoteIPAddress);this.port=port;IPEndPointremoteEndPoint=newIPEndPoint(this.remoteIPAddress,this.port);

python - 在 python 中读取套接字时,os.read 和 socket.recv 之间有什么区别吗?

假设我有一个socket。这两行代码有什么区别?第1行:os.read(some_socket.fileno(),1024)第2行:some_socket.recv(1024)...除了第一个不能在Windows上运行的事实。换句话说,我可以用第二行代替第一行吗?我有一个代码库还没有真正用Windows测试过,这导致了麻烦。 最佳答案 第1行使用带下划线的文件描述符来读取套接字,因此它是平台相关的。使用第2行,因为它是一种可移植的、多平台的方式来完成同样的事情。强制性:如果您正在做任何严肃的事情,最好避免处理低级套接字。他们很难做到