epoll定义及配置
- epoll是Linux内核为处理大批量文件描述符而作了改进的poll,是Linux下多路复用IO接口select/poll的增强版本,它能显著提高程序在大量并发连接中只有少量活跃的情况下的系统CPU利用率。另一点原因就是获取事件的时候,它无须遍历整个被侦听的描述符集,只要遍历那些被内核IO事件异步唤醒而加入Ready队列的描述符集合就行了。
- 目前epell是linux大规模并发网络程序中的热门首选模型
- epoll除了提供select/poll那种IO事件的水平触发(Level Triggered)外,还提供了边缘触发(Edge Triggered),这就使得用户空间程序有可能缓存IO状态,减少epoll_wait/epoll_pwait的调用,提高应用程序效率。
首先,使用cat /proc/sys/fs/file-max
命令查看一个进程可以打开文件描述符的最大数目,如下图:
然后,使用sudo vi /etc/security/limits.conf
命令查看最大打开文件描述符的限制,并在该文件中写入以