您的位置:首页 > 运维架构 > Linux

Linux -- select 与 poll 事件模型详解

2017-11-28 18:25 381 查看

select 与 poll 工作原理:

1、select 主要是采用轮询的方式来实现对就绪的 fd 处理:
2、poll 和 select 基本相同,主要不同在于 poll 没有对 fd 数量限制

工作模型:



工作流程:

1、用户态创建了网络 IO 连接,假设一个 socket 连接就是一个 fd 文件描述符,那么将 fd 添加到 fd_set 集合中
2、将 fd_set 集合从用户态 copy 到内核态
3、遍历这个 fd_set 集合,找出所有已经就绪的 fd,执行对应 fd 的相关操作
4、将内核态的 fd_set 集合拷贝到用户态

伪代码:

fd = iosocket_coonnect()  #建立网络连接
fd_set.add(fd)  #向fd_set集合中添加fd
copy_from_user(fd_set)   #从用户态拷贝 fd_set 到内核态
for fd in fd_set:   #遍历 fd_set 对就绪的 fd 执行相关操作
doing(fd)


缺点:

1、每次调用 select ,都需要把 fd 集合从用户态拷贝到内核态,当 fd 比较大的时候,开销大
2、每次都需要对 fd_set 集合进行遍历,开销比较大
3、select 可支持的 fd 描述符比较少,一般是1024 或2048, 可以修改,从新编译内核实现增大,到时效果不好
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  linux 事件模型 select