Python select解析
一、首先列一下,sellect、poll、epoll三者的区别
1、select
a、select最早于1983年出现在4.2BSD中,它通过一个select()系统调用来监控多个文件描述符的数组,当select返回后,该数组中就绪的文件描述符便会被内核修改标志位,使得进程可以获得这些文件描述符从而进行后续的读写操作。
b、select目前几乎在所有的平台上支持,其良好跨平台支持也是它的一个优点,事实上从现在看来,这也是它所剩不多的优点之一。
c、select的一个缺点在于单个进程能够监视的文件描述符的数量存在最大限制,在Linux上一般为1024,不可以通过修改宏定义甚至重新编译内核的方式提升这一限制。
d、另外,select()所维护的存储大量文件描述符的数据结构,随着文件描述符数量的增大,其复制的开销也线性增长。同时,由于网络相应时间的延迟使得大量TCP连接处于非活跃状态,但调用select()会对所有
2、poll
a、poll在1986年诞生于System V Release3,它和select在本质上没有多大差别,但是poll没有最大文件描述符数量限制。原因是它基于链表存储的。
b、poll和select同样存在一个缺点就是,包含大量文件描述符的数组被整体复制于用户态和内核的地址空间之间,而不论这些文件描述符是否就绪,它的开销随着文件描述符数量的增加而线性增大。
c、select()和poll()将就绪的文件描述符告诉进程后,如果进程没有对其进行IO操作,那么下次调用select()和poll()的时候将再次报告这些文件描述符,所以他们一般不会丢失就绪的消息,这种方式称为水平触发。
3、epoll
a、直到linux2.6才出现了由内核直接支持的实现方法,那就是epoll,它几乎具备了之前所说的一切优点,被公认为是linux2.6下性能最好的多路I/O就绪通知方法。
b、epoll可以同时支持水平出发和边缘触发(Edge Triggered,只告诉进程哪些文件描述符刚刚变为就绪状态),只说一遍,如果我们没有采取行动,那么它将不会再次告知,这种方式称为边缘触发),理论上边缘触发的性能要更高一些,但是代码实现相当复杂。
c、epoll同样只告知那些就绪的文件描述符,而且当我们调用epoll_wait()获得就绪文件描述符时,返回的不是实际的描述符,而是一个代表就绪描述符数量的值,你只需要去epoll指定的一个数组中依次取得相应数量的文件描述符即可,这里也使用了内存映射(mmap)技术,这样便彻底省掉了这些文件描述符在系统调用时复制的开销。
d、另一个本质的改进在于epoll采用基于事件的就绪通知方式。在select/poll中,进程只有在调用一定的方法后,内核才会对所有监视的文件 描述符进行扫描,而epoll事先通过epoll_ctl()来注册一个文件描述符,一旦基于某个文件描述符就绪时,内核会采用类似callback的回调机制,迅速激活这个文件描述符,当进程调用epoll_eait()时便得到通知。
最新文章
- 读《linux内核完全注释》的FAQ
- JSX语法简介
- 如何解决Response.Redirect方法传递汉字丢失或乱码问题?
- 常用的STL查找算法
- 作业6 NABCD模型分析,产品Backlog
- 如何取消FLEX里模态窗口的毛玻璃效果
- 如何将C++中的SOCKADDR_IN*参数类型转换成C#中的参数类型
- 【HDOJ】1086 You can Solve a Geometry Problem too
- 【FJOI2014】【偏导+数学】病毒防护带
- WordPress Duplicator 0.4.4 Cross Site Scripting
- 地图:CLGeocoder地址解析与反地址解析
- JS图标插件
- javascript函数apply和call
- 多说评论一次导回 Typecho 本地数据库
- 剥掉层层外衣后的RPC是什么样子的?
- 牛客练习赛 A题 筱玛的快乐
- bootstrap简单使用布局、栅格系统、modal标签页等常用组件入门
- OnlineJudgeFE之前端二次开发
- bootstrap学习笔记(4)
- 基于Django-Cookie的CBV和FBV的用户验证装饰器