Linux网络:I/O多路转接poll

目录

一、poll函数解析

二、events和revents事件取值

三、poll的优点

四、poll的缺点


一、poll函数解析

poll函数接口:

#include <poll.h>

int poll(struct pollfd *fds, nfds_t nfds, int timeout);

参数解析:

// struct pollfd 结构

struct pollfd

{

int fd; /* file descriptor */

short events; /* requested events */

short revents; /* returned events */

};

参数一:

fds 是一个 poll 函数一个监听的结构列表。

每一个结构体元素中, 包含了三部分内容:

1、文件描述符:fd

2、监听的事件集合:events

3、返回的事件集合:revents

参数二:

nfds 表示 fds 数组的长度是多少

参数三:

timeout 表示所设置的 poll 函数的超时时间, 单位是毫秒(ms)

poll函数返回值:

返回值小于 0, 表示出错;

返回值等于 0, 表示 poll 函数等待超时;

返回值大于 0, 表示 poll 由于监听的文件描述符就绪而返回。

二、events和revents事件取值

|-------------|-----------------------|
| | |
| POLLIN | 数据(包括普通/优先数据)可读 |
| POLLRDNORM | 普通数据可读 |
| POLLRDBAND | 优先级带数据可读 |
| POLLPRI | 高级优先级数据可读,如TCP带外数据 |
| POLLOUT | 数据(包括普通/优先数据)可写 |
| POLLWRNORM | 普通数据可写 |
| POLLWRBAND | 优先级带数据可写 |
| POLLERR | 错误 |
| POLLHUP | 挂起 |
| POLLNVAL | 文件描述符未打开 |
| POLLRDHUP | TCP连接被对方关闭,或者对方关闭了写操作 |

三、poll的优点

不同于 select 使用三个位图来表示三个 fdset 的方式,poll 使用一个 pollfd 的指针实现。

**1、**pollfd 结构包含了要监视的 event 和发生的 event,不再使用 select参数值的传递方式. 接口使用上比 select 更方便。

**2、**poll 并没有最大数量的限制 (但是数量过大后性能也是会下降),理论上我们传过去一个多大的数组,poll就处理多大。

四、poll的缺点

**1、**和 select 函数一样,poll 返回后,需要轮询 pollfd 来不断获取已经就绪的描述符。

**2、**每次调用 poll 都需要把大量的 pollfd 结构从用户态拷贝到内核中,如果pollfd过大会影响效率。

**3、**如果同时连接的大量客户端,在同一时刻可能只有很少客户端的处于就绪的状态, 因此随着需要监视的描述符数量增长, 其效率也会呈线性下降。

相关推荐
LH_R1 小时前
OneTerm开源堡垒机实战(四):访问授权与安全管控
运维·后端·安全
用户31187945592181 小时前
Kylin Linux 10 安装 glib2-devel-2.62.5-7.ky10.x86_64.rpm 方法(附安装包)
linux
Raymond运维1 小时前
MariaDB源码编译安装(二)
运维·数据库·mariadb
涛啊涛2 小时前
Centos7非LVM根分区容量不足后扩容,对调硬盘挂载/
linux·磁盘管理
JuiceFS18 小时前
从 MLPerf Storage v2.0 看 AI 训练中的存储性能与扩展能力
运维·后端
CYRUS_STUDIO21 小时前
用 Frida 控制 Android 线程:kill 命令、挂起与恢复全解析
android·linux·逆向
熊猫李1 天前
rootfs-根文件系统详解
linux
chen9451 天前
mysql 3节点mgr集群部署
运维·后端
LH_R1 天前
OneTerm开源堡垒机实战(三):功能扩展与效率提升
运维·后端·安全
dessler1 天前
Hadoop HDFS-高可用集群部署
linux·运维·hdfs