epoll的实现原理(1)
本文是学习epoll过程中的笔记,方便自己理解,基本翻译自下面的文章:
The Implementation of epoll(1)
The Implementation of epoll(2)
概述
epoll与传统的I/O多路复用技术之间的最大差别在于,用户只需要获取一个epoll实例,然后将文件描述注册到它上面(一次性),而不是每次将大量文件描述符传递到内核当中。
epoll实例的创建
通过调用epoll_create(2)
或者epoll_create1(2)
来请求实例,返回的是文件描述符。所以,epoll也是可以轮询的,用于一些高级用法。
epoll实例实际的重要部分是内核数据struct eventpoll
,这个数据结构几乎维护了epoll实例正常工作所需要的所有内容。它的创建方法如下:
/*
* Create the internal data structure ("struct eventpoll").
*/
error = ep_alloc(&ep);
ep_alloc()
所做的,只是从内核堆分配足够的空间来保存eventpoll
(ep),然后epoll_create()
去尝试在进程中获取未使用的描述符。如果能够获取到描述符,它会尝试从系统获取一个匿名的inode (什么是匿名inode?)。 这里注意,epoll_create()
将eventpoll
的指针保存在了文件的private_data
中,这样访问eventpoll
非常方便。
然后,epoll_create()
将匿名inode与文件描述符绑定起来,并向用户返回文件描述符fd。
epoll实例如何保存它监控的文件描述符
epoll
使用