词条简介如下:
epoll是Linux内核为处理大批量文件描述符而作了改进的poll,是Linux下多路复用IO接口select/poll的增强版本,它能显著提高程序在大量并发连接中只有少量活跃的情况下的系统CPU利用率。
另一点原因就是获取事件的时候,它无须遍历整个被侦听的描述符集,只要遍历那些被内核IO事件异步唤醒而加入Ready队列的描述符集合就行了。
epoll除了提供select/poll那种IO事件的水平触发(Level Triggered)外,还提供了边缘触发(Edge Triggered),这就使得用户空间程序有可能缓存IO状态,减少epoll_wait/epoll_pwait的调用,提高应用程序效率。
一、问题的发现:
在某一天实现了单进程非堵塞的并发服务器之后,发现了一个问题,在实现的并发的过程中,我创建了一个list,将客户端的套接字接收并append这个列表,从而使服务器不断的遍历这个列表来确认客户端是否发送数据,确保客户端的需求得到完整的满足之后再从这个列表中删除client_socket,但当大量的客户端到来时,不断的遍历会给服务器造成不必要的资源浪费
s = socket.socket(socket.AF_INET,socket.SOCK_STREAM)
# 设定套接字的选项值
s.setsockopt(socket.SOL_SOCKET,socket.SO_REUSEADDR, 1)
# 绑定ip
server_addr = ('',xxxx)
s.bind((server_addr))
# 响应模式
s.listen(