您的位置:首页 > 运维架构 > Linux

linux epoll 简介

2016-05-19 21:04 211 查看

1. linux epoll简介

本文简单介绍linux epoll功能,大部分内容是
man 7 epoll
的翻译,一部分是自己的理解;如果有人觉得不对,敬请指正。

epoll实现了I/O事件通知功能,具体功能类似于poll(你可以认为是扩展的poll–extended poll):

监视多个文件描述符,并监测其I/O事件是否发生,比如可读、可写等。

它对监测大规模的文件描述符有很好的扩展性。

epoll 提供如下API:

(I)epoll_create 创建epoll实例,并返回一个引用到该实例的文件描述符(内核新增epoll_create1对epoll_create的功能做了扩展);

(II)epoll_ctl 将我们感兴趣(需要监测)的文件描述符注册到epoll实例;

(III)epoll_wait等待I/O事件,如果没有感兴趣的I/O事件发生,阻塞调用线程 (阻塞的时间和具体参数有关系)。

其中 需要注意的是,epoll API 的使用分为两种情况:

(I)边缘触发(Edge-Triggered Interface)

(II)水平触发(Level-Triggered Interface)

二者区别下文再继续分析。

和epoll相关的数据结构和函数定义在
sys/epoll.h
文件里。

2. 水平触发(Level-triggered)和边缘触发(Edge-triggered)

epoll 事件分发接口分为两种,一个是水平触发(LT),一个是边缘触发(ET)。两种机制的区别如下所述。假定场景如下:

PS:这个博客还没有写完,待续。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: