epoll 模型

一直以来觉得自己对epoll的理解还是可以的,没想到今天通过看同事的一段代码,及后来查资料发现还有很多未知的属性不知道。学无止境啊。 epoll的理解 - binary service - binary service的博客

1、如果fd被注册到两个epoll中时,如果有时间发生则两个epoll都会触发事件。
2、如果注册到epoll中的fd被关闭,则其会自动被清除出epoll监听列表。
3、如果多个事件同时触发epoll,则多个事件会被联合在一起返回。
4、epoll_wait会一直监听epollhup事件发生,所以其不需要添加到events中。
5、为了避免大数据量io时,et模式下只处理一个fd,其他fd被饿死的情况发生。linux建议可以在fd联系到的结构中增加ready位,然后epoll_wait触发事件之后仅将其置位为ready模式,然后在下边轮询ready fd列表。

6、epoll_ctl epoll的事件注册函数,其events参数可以是以下宏的集合:
EPOLLIN:    表示对应的文件描述符可以读(包括对端SOCKET正常关闭);
EPOLLOUT:   表示对应的文件描述符可以写;
EPOLLPRI:   表示对应的文件描述符有紧急的数据可读(这里应该表示有带外数据到来);
EPOLLERR:   表示对应的文件描述符发生错误;写已关闭socket pipe broken 
EPOLLHUP:   表示对应的文件描述符被挂断;譬如收到RST包。在注册事件的时候这个事件是默认添加。
EPOLLRDHUP: 表示对应的文件描述符对端socket关闭事件,主要应用于ET模式下。
在水平触发模式下,如果对端socket关闭,则会一直触发epollin事件,驱动去处理client socket。
在边沿触发模式下,如果client首先发送协议然后shutdown写端。则会触发epollin事件。但是如果处理程序只进行一次recv操作时,根据recv收取到得数据长度来判读后边是否还有需要处理的协议时,将丢失客户端关闭事件。
EPOLLET: 将EPOLL设为边缘触发(Edge Triggered)模式,这是相对于水平触发(Level Triggered)来说的。

EPOLLONESHOT:只监听一次事件,当监听完这次事件之后,如果还需要继续监听这个socket的话,需要再次把这个socket加入到EPOLL队列里。







Epoll实验总结  

2012-09-06 15:54:10|  分类: network_program |  标签:epoll  c  |字号 订阅

一、超时实验

建立一个阻塞模式的tcp连接到一个没有监听的服务端口(肯定连不上,然后等待超时),然后将这个socket描述符,交由epoll管理。注册的epoll事件为

 

         event = EPOLLIN | EPOLLOUT | EPOLLRDHUP | EPOLLERR | EPOLLET |

EPOLLPRI | EPOLLHUP

 

结果:当tcp连接超时的时候,触发的事件有EPOLLIN  EPOLLOUT EPOLLRDHUP EPOLLERREPOLLHUP,也就是只有紧急数据的事件没有发生。

 

二、调用read(),返回0时,继续write()

建立一个阻塞模式的tcp连接到有监听的服务器端口上,然后将这个socket描述符,交由epoll管理。注册的epoll事件为

 

         event = EPOLLIN | EPOLLOUT | EPOLLRDHUP | EPOLLERR | EPOLLET |

EPOLLPRI | EPOLLHUP

当该描述符可写时,写10字节的数据到服务端;当该描述符可读时,读10字节的数据;服务端读10字节的数据,然后休眠5秒,之后close连接。

实验结果,总结如下:

1,  tcp三次握手一旦完成,该socket描述符的EPOLLOUT触发,即可写

2,  服务端休眠5秒后,关闭连接。触发的事件有EPOLLIN  EPOLLOUT EPOLLRDHUP EPOLLERREPOLLHUP。此时read返回0write仍然可写

3,  之后又触发了EPOLLIN  EPOLLOUT事件。此时read仍然返回0write出错,错误为SIGPIPE。这次触发的原因是,在2中的write了一个closed的连接,由于非阻塞,造成write成功的假象,所以这儿epoll又接到了通知,弥补上一步的错误。

 

三、调用read,返回0,不再write

建立一个阻塞模式的tcp连接到有监听的服务器端口上,然后将这个socket描述符,交由epoll管理。注册的epoll事件为

 

         event = EPOLLIN | EPOLLOUT | EPOLLRDHUP | EPOLLERR | EPOLLET |

EPOLLPRI | EPOLLHUP

read返回0后,不再write数据到服务端;服务端读10字节的数据,然后休眠5秒,之后close连接。

实验结果:

1,  tcp三次握手一旦完成,该socket描述符的EPOLLOUT触发,即可写

2,  触发EPOLLIN  EPOLLOUT EPOLLRDHUP  EPOLLERREPOLLHUP。此时read返回0。之后不再有事件触发

 

四、ET模式下,只需注册EPOLLIN | EPOLLOUT就可以了,如果有错误发生,这两个事件也被能触发,然后判断错误类型就可以了


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值