- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 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
您可能关注的文档
- Chapter1 gas state-应化.ppt
- Chapter11 Population.ppt
- Chapter1.6-Propositional_logic(Rules of Inference).ppt
- bpe8720防爆应急平台灯和ga107平台灯价格.docx
- Chapter2 Accounting income and assets.ppt
- chapter2_Language Basics_flow Control.ppt
- chapter2_进程管理.ppt
- Chapter2-Fiber optics and Gradient-index optics.ppt
- Chapter5_6 最小二乘b.ppt
- chapter6 Short-Term Notes Payable.ppt
- englishi unit1-1.ppt
- eradicate the sandstorm.ppt
- Equation of State Study in UU collisionsat CSR, Lanzhou.ppt
- ESD设计秘籍(上).doc
- Esper学习之十三:EPL语法(九).docx
- ESFramework_.doc
- Estimating the Connection Inductance of a Decoupling Capacitor.doc
- Evaluating background and prior knowledge A case study on engineering graphics learning.doc
- EVA Part1.ppt
- Everytime 歌词.ppt
原创力文档


文档评论(0)