epoll使用详解.docVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
epoll使用详解

epoll使用详解 【epoll简介】 ? ?Linux平台上传统的I/O复用模型有select和poll模型,但二者在解决大量并发请示时却表现不佳。与select/poll相比,epoll的优点体现在以下三个方面: 1)?支持进程打开大数目的文件描述符(FD) select最大的缺点是一个进程所打开的文件描述符是有一定限制的,默认值是 2048,这对于那些需要支持成千上万连接数目的服务器来说显然是太少了。epoll则没有这个限制,它所支持的文件描述符上限是最大可以打开的文件数 目,具体数目和系统内存大小有关。如在1GB内存的服务器上可打开的FD大约是10万左右。 2)?I/O效率不随文件描述符数量增加而线性下降 传统的select/poll保存一个很大的文件描述符集合,但是任一时间只有 部分的FD是“活跃”的,但是select/poll每次调用都会线性扫描全部的集合,导致效率随着FD数目增加而线性下降,但是epoll不存在这个问 题,它只会对“活跃”的FD进行操作,这是因为内核实现中epoll是根据每个FD上面的callback函数实现的。只有“活跃”的FD才会主动去调用 callback函数,在这点上,epoll实现了一个“伪”AIO,效率远在select/poll之上。 3)?加速内核与用户空间的消息传递 无论是select还是poll都需要内核把FD上发生的消息通知给用户空间,在这一点上 poll根据文件描述符组织信息带来了较高的效率,而epoll也继承丁poll的这个优点,并做了更高效的改进:poll中的文件描述符集合保存在程序 的地址空间,而epoll为了减少用户空间和内核空间之问的拷贝,使用mmap机制把这些文件描述符集合移动到内核中。应用程序通过系统调用给内核提供了 一个需要监控的文件描述符列表,然后使用另外一个不同的系统调用来监控这些文件描述符。当内核发现监控的事件发生时,就发出一个通知,而应用程序此时只需 要在内核中对前面建立的列表中查询对应的文件描述符即可。基于这些调整,epoll具有良好的扩展性,当用于监控大量描述符时,可以带来很大的性能提升。 ? 【epoll 使用方法】 ? ?epoll的接口非常简单,一共就三个函数: 1. int epoll_create(int size); 创建一个epoll的句柄,size用来告诉内核这个监听的数目一共有多大。这个参数不同于select()中的第一个参数,给出最大监听的 fd+1的值。需要注意的是,当创建好epoll句柄后,它就是会占用一个fd值,在linux下如果查看/proc/进程id/fd/,是能够看到这个 fd的,所以在使用完epoll后,必须调用close()关闭,否则可能导致fd被耗尽。 2. int epoll_ctl(int epfd, int op, int fd, struct epoll_event *event); epoll的事件注册函数,它不同与select()是在监听事件时告诉内核要监听什么类型的事件,而是在这里先注册要监听的事件类型。第一个参数是epoll_create()的返回值,第二个参数表示动作,用三个宏来表示: EPOLL_CTL_ADD:注册新的fd到epfd中; EPOLL_CTL_MOD:修改已经注册的fd的监听事件; EPOLL_CTL_DEL:从epfd中删除一个fd; 第三个参数是需要监听的fd,第四个参数是告诉内核需要监听什么事,struct epoll_event结构如下: typedef union epoll_data { ?? ?void *ptr; ?? ?int fd; ?? ?__uint32_t u32; ?? ?__uint64_t u64; } epoll_data_t; struct epoll_event { ?? ?__uint32_t events; /* Epoll events */ ?? ?epoll_data_t data; /* User data variable */ }; ? events可以是以下几个宏的集合: EPOLLIN :表示对应的文件描述符可以读(包括对端SOCKET正常关闭); EPOLLOUT:表示对应的文件描述符可以写; EPOLLPRI:表示对应的文件描述符有紧急的数据可读(这里应该表示有带外数据到来); EPOLLERR:表示对应的文件描述符发生错误; EPOLLHUP:表示对应的文件描述符被挂断; EPOLLET: 将EPOLL设为边缘触发(Edge Triggered)模式,这是相对于水平触发(Level Triggered)来说的。 EPOLLONESHOT:只监听一次事件,当监听完这次事件之后,如果还需要继续监听这个so

文档评论(0)

sd44055 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档