关于Linux accpet()的错误处理

     Linux下,accept()把已等到的网络错误传给新建立的连接,当作是accept()返回的错误。这同其他的BSD实现是不同的。为了可靠运行,应该在accept()之后检测协议已定义的一些网络错误,并把这些错误当作EAGAIN并重试。对于TCP/IP协议来说,主要有错误:ENETDOWN,EPROTO,ENOPROTOOPT,EHOSTDOWN,ENONET,EHOSTUNREACH,EOPNOTSUPP和ENETUNREACH。

EAGAIN或EWOULDBLOCK
socket为非阻塞状态并且当前没有连接存在就会返回EAGAIN或EWOULDBLOCK。posix.1-2001允许返回值是这两个中的任意一个,并且不需要两个常数的值是相同的,这样应用程序移植的时候有更好的兼容性。
EBADF
该描述符无效。
ECONNABORTED
连接已被终止。
EFAULT
addr参数不在用户地址空间的可写的部分。
EINTR
有效的连接到达之前,系统调用被中断。了解更多信息可以参考signal(7)。
EINVAL
套接字未侦听连接,或地址长度是无效的(例如,是负的)。
EINVAL
(accept4())在标志的值无效。
EMFILE
每个打开的文件描述符的过程已达到极限。
ENFILE
在打开的文件总数已达到极限的系统。
ENOBUFS, ENOMEM
没有足够的可用内存。这往往意味着内存分配是通过socket缓冲区的范围有限,不是系统内存。
ENOTSOCK
引用一个文件描述符,不是一个插座。
EOPNOTSUPP
引用的类型不是sock_stream插座。
EPROTO
协议错误。
此外,Linux accept()可能会失败,如果:
EPERM
防火墙禁止连接。
此外,新版本Socket定义的新的网络错误可能被返回。不同的Linux内核可以返回其他错误,如enosr,esocktnosupport,eprotonosupport,etimedout。跟踪过程中还可以看到ERESTARTSYS。

郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。