Articles of networking

可以在一个连接的套接字读取()函数返回零字节?

我知道read()是一个阻塞调用,除非我使套接字非阻塞。 所以我期望read()调用请求4K的数据应该返回一个正值(读取的字节数)或错误-1(客户端可能的连接重置等)。 我的问题是:可以read()在任何情况下返回“0”? 我这样处理read(): if ((readval = read(acceptfd, buf, sizeof(buf) – 1)) < 0) { } else { buf[readval] = 0; //Do some thing with data } 这个代码炸弹,如果read()返回零,我知道如何解决它。 但是有可能read()返回零吗?

“零复制networking”与“内核旁路”?

“零复制networking”和“内核旁路”有什么区别? 他们是两个词组是相同的还是不同的? 内核是否绕过“零复制networking”中使用的技术,这是关系?

使用GNU / Linux系统调用`splice`在Haskell中进行Zero-Copy Socket到Socket的数据传输

更新:Nemo先生的回答帮助解决了这个问题! 下面的代码包含修复! 请参阅下面的nb False和nb True调用。 还有一个叫做splice的新的Haskell软件包 ,它具有最好的套接字到套接字数据传输循环的操作系统特定的和可移植的实现。 我有以下(Haskell)代码: #ifdef LINUX_SPLICE #include <fcntl.h> {-# LANGUAGE CPP #-} {-# LANGUAGE ForeignFunctionInterface #-} #endif module Network.Socket.Splice ( Length , zeroCopy , splice #ifdef LINUX_SPLICE , c_splice #endif ) where import Data.Word import Foreign.Ptr import Network.Socket import Control.Monad import Control.Exception import System.Posix.Types import System.Posix.IO #ifdef LINUX_SPLICE import Data.Int import […]

为什么C99抱怨存储大小?

这是我在Linux上编译的一些代码: #include <net/if.h> int main() { struct ifreq ifr; } gcc test.c 。 gcc -std=gnu99 test.c 。 gcc -std=c99 test.c失败,出现以下错误: test.c: In function 'main': test.c:4:16: error: storage size of 'ifr' isn't known C99有什么不同,它不喜欢Linux中struct ifreq的定义?

从PHP应用程序通过networking打印

我有一组打印机通过networking连接,分配给每台打印机的静态IP。 现在我有一个PHP Web应用程序运行在需要发送打印作业的Linux服务器上,通过networking打印到这些打印机上。 这可能使用lpr或杯子,我怎么去做。

如何处理Linux套接字revellent POLLERR,POLLHUP和POLLNVAL?

我想知道当轮询设置这些位时应该做什么? closures套接字,忽略它或什么?

在c / c ++中查找可用的networking接口

有没有人知道ac / c + +代码find可用的networking接口? 我一直在寻找一些代码,但大部分时间都是相当复杂的。 有一个简单的方法来做到这一点? UPDATE 在Ubuntu / Linux上

如何通过Java获得Linux上的计算机的IP?

如何通过Java获得Linux上的计算机的IP? 我search了networking的例子,我发现一些关于NetworkInterface类,但我不能包裹我的头如何获得IP地址。 如果我有多个networking接口在同一时间运行会发生什么? 哪个IP地址将被返回。 我真的很感激一些代码示例。 PS:我到目前为止已经使用了InetAddress类,这是跨平台应用程序的一个糟糕的解决scheme。 (WIN / Linux的)。

仅使用proc获取本地networking接口地址?

如何仅使用proc获取所有networking接口的(IPv4)地址? 经过一番广泛的调查,我发现了以下几点: ifconfig使用SIOCGIFADDR ,这需要打开套接字并提前了解所有接口名称。 它也没有logging在Linux上的任何手册页面上。 proc包含/proc/net/dev ,但这是接口统计信息的列表。 proc包含/proc/net/if_inet6 ,这正是我所需要的,但对于IPv6。 通常在proc中很容易find接口,但实际的地址是很less使用的,除非明确指出某个连接的一部分。 有一个名为getifaddrs的系统调用,这是你期望在Windows中看到的非常“神奇”的function。 它也在BSD上实现。 但是,它不是非常面向文本的,所以很难从非C语言中使用。

如何closures一个死亡程序打开的sockets?

我有一个Python应用程序,它打开一个简单的TCP套接字与另一个主机上的另一个Python应用程序通信。 有时程序会出错,或者我会直接杀死它,在任何情况下,套接字可能会在未知的时间被打开。 下一次我去运行程序,我得到这个错误: socket.error: [Errno 98] Address already in use 现在程序总是试图使用相同的端口,所以它看起来好像还是开放的。 我查了一下,很确定程序没有在后台运行,但我的地址仍在使用中。 所以,我怎么手动(或以其他方式)closures套接字/地址,以便我的程序可以立即重新使用它? 更新 根据迈克的回答,我检查了socket(7)页面,看着SO_REUSEADDR: SO_REUSEADDR Indicates that the rules used in validating addresses supplied in a bind(2) call should allow reuse of local addresses. For AF_INET sockets this means that a socket may bind, except when there is an active listening socket bound to […]