select限制:
用select实现的并发服务器,能达到的并发数,受两方面的限制:
1.一个进程能打开的最大文件描述符限制。这可以通过调整内核参数。
2.select中的fd_set集合容量的限制(FD_SETSIZE),这需要重新编译内核。
poll的限制:
一个进程能打开的文件描述符个数是有限的。
两者共同点:
内核要遍历所有文件描述符,直到找到发生事件的文件描述符。
查看一个进程能打开的最大文件描述符:
ulimit -n
epoll与select、poll的区别:
1.相比于select与poll最大的好处在于它不会随着监听fd数目的增长而降低效率。
2.内核中的select与poll的实现是采用轮询来处理的,轮询的fd数目越多,自然耗时越多。
3.epoll的实现是基于回调的,如果fd有期望的事件发生就通过回调函数将其加入epoll就绪队列中,也就是说它只关心“活跃”的fd,与fd数目无关。
4.在内核把fd消息通知给用户处理方面,select和epoll采用了内存拷贝方法。而epoll采用了共享内存的方式。
5.epoll不仅会告诉应用程序有I/O事件到来,还会告诉应用程序相关的信息,这些信息是应用程序填充的。因此根据这些信息应用程序就能直接定位到事件,而不必遍历整个fd集合。