select与poll、epoll

来源:互联网 发布:淘宝团队架构 编辑:程序博客网 时间:2024/05/29 16:54

所能监控文件描述符的数量:

select
1)一个进程所能打开最大文件描述符个数是有限的2)FD_SETSIZE(fd_set)1024
poll
1)一个进程所能打开的最大文件秒速福的个数是有限的

ulimit -n number调整进程所能打开的文件描述个数

共同点:
    内核要遍历所有文件描述符,知道找到所发生事件的文件描述符(这是他们性能不高的原因,随着文件描述符的正常,性能会指数级下降
epoll与select、poll的区别
1)相比于select与poll,epoll最大的好处在于它刽随着坚挺fd数目的增长而降低效率2)内核中的select与poll的实现是采用轮询来处理的,轮询的fd数目越多,耗时就会越多3)epoll的实现是基于回调的,如果fd有期望的事件发生就通过回调函数将其加入到epoll就绪队列中,也就是说他只关心“活跃的”fd与fd数目无关4)内核/用户空间 内存拷贝问题,如何让内核吧fd消息通知给用户控件呢?在这个问题上select/poll采取了内存拷贝方法,而epoll采用了共享内存的方式5)epoll不仅会告诉应用程序有I/O时间的到来,还会告诉应用程序相关的信息,这些信息是应用程序填充的,因此根据这些信息引用程序就能直接定位到事件,而不必遍历整个fd集合
0 0
原创粉丝点击