网络: 多路复用

  • 概念: 多路复用: 一种通信传输技术, 使多条数据流或信号共享同一传输介质
  • 网络中的多路复用: 一个进程能够同时监控多个文件描述符的IO事件

特点

select

缺点

  • 设置关注文件描述符的结构是位图, 有数量限制
  • fdset无法复用, 每次都要初始化
  • 用户态和内核态之间的拷贝较多
  • 检查关注的fd, 已就绪的fd都需要遍历

poll

优点

  • 采用结构体, 解决select文件描述符的个数限制

缺点

  • 用户态和内核态之间的拷贝较多
  • 检查关注的fd, 已就绪的fd仍需要遍历

epoll

优点

  • 检查就绪的文件描述符更快(为O(1), 就绪队列结构)
  • 不用频繁的在用户态和内核态之间拷贝(红黑树 + 双链表, 会记录要关注的fd和就绪的fd). 相比于select不用老是传递之前的文件描述符

缺点

  • 内核要维护红黑树 + 双链表(更占内存)
  • 当要监听的文件描述符较少时, 其速度不一定比poll快

epoll触发机制

  • LT(水平触发): 只要底层有事件就绪且没被取走, 就会一直通知上层
  • ET(边缘触发): 只有就绪事件变化的时候, 才会通知上层(且只通知一次)

原理

select

  • 将关注的所有fd, 一次性从用户态拷贝到内核态
  • 在内核态中遍历每个fd, 检测是否有数据到达
  • 将所有fd状态从, 从内核态拷贝回用户态, 并返回就绪fd个数
  • 用户态遍历所有fd, 找到已就绪的fd, 然后进行事件处理

poll

  • 和select类似(只是用一个结构体封装了一下)

epoll

  • 和select,poll类似, 不过在内核维护了红黑树 + 双链表且使用回调机制减少了select的缺点

操作

  • select

头文件: <sys/select.h>

int select(int nfds, fd_set *readfds, fd_set *writefds, fd_set *exceptfds, struct timeval *timeout)

nfds   : 需要监视的最大的文件描述符值+1. (用来确定遍历范围)
read   : 可读文件描述符的集合
write  : 可写文件描述符的集合
except : 异常文件描述符的集合
timeout: 超时时间(若超过该时间, 还没有事件就绪就返回) NULL: 一直阻塞0: 不阻塞

fd_set系列

void FD_ZERO(fd_set *set);              // 用来清除描述词组set的全部位
void FD_CLR(int fd, fd_set *set);       // 用来清除描述词组set中相关fd的位
void FD_SET(int fd, fd_set *set);       // 用来设置描述词组set中相关fd的位
int  FD_ISSET(int fd, fd_set *set);      // 用来测试描述词组set中相关fd的位是否为真

  • poll

头文件: <poll.h>

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

struct pollfd {int fd;         //文件描述符short events;   //监听事件集合short revents;  //返回事件集合
};nfds: fds数组的长度
timeout: 超时时间

events与revents的取值

  • epoll

epoll_create

函数  : int epoll_ctl(int epfd, int op, int fd, struct epoll_event *event);
功能  : 创建一个epoll模型
返回值: 用一个数表示这个epoll
参数  : size: 文件描述符个数
注    : 但自从linux2.6.8之后,size参数是被忽略的用完之后, 必须调用close()关闭

epoll_ctl

函数:int epoll_ctl(int epfd, int op, int fd, struct epoll_event *event);
功能:注册要监听的事件类型epfd : epoll_create()的返回值(epoll的句柄)
fd   : 需要监听的fd
event: 告诉内核需要监听什么事
op   : 用三个宏来表示EPOLL_CTL_ADD :注册新的fd到epfd中;EPOLL_CTL_MOD :修改已经注册的fd的监听事件;EPOLL_CTL_DEL :从epfd中删除一个fd;

epoll_wait

int epoll_wait(int epfd,struct epoll_event * events,int maxevents, nt timeout);
功能: 收集在epoll监控的事件中已经发送的事件events   :分配好的epoll_event结构体数组.
maxevents: 告诉内核这个events有多大,这个 maxevents的值不能大于创建epoll_create()时的size.
timeout  : 超时时间(0会立即返回,-1是永久阻塞)返回值:成功 :返回对应I/O上已准备好的文件描述符数目0    :表示已超时小于0:表示函数失败epoll将会把发生的事件赋值到events数组中 
events不可以是空指针,内核只负责把数据复制到这个events数组中,不会去帮助我们在用户态中分配内存

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/564540.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

麒麟系统中使用nginx发布项目

1. 安装Nginx sudo apt-get update #进行所有安装操作前都要执行这一句 sudo apt install nginx #出现询问就Yes参考具体 Nginx—在linux的ubuntu系统上的安装使用 2. 修改发布文件 将打包好的dist文件夹中的所有文件覆盖下面这个文件夹中的所有文件 如果出现没有权限替…

阿里云服务器价格表2024,最新报价2核2G/2核4G/4核8G/8核16G/16核32G

2024年腾讯云服务器优惠价格表&#xff0c;一张表整理阿里云服务器最新报价&#xff0c;阿里云服务器网整理云服务器ECS和轻量应用服务器详细CPU内存、公网带宽和系统盘详细配置报价单&#xff0c;大家也可以直接移步到阿里云CLUB中心查看 aliyun.club 当前最新的云服务器优惠券…

【Nebula笔记】简介及安装

目录 一、简介 (一) 什么是图数据库 二、安装 (一) 原生安装 (二) Docker & Docker compose 1. Docker安装 Linux Window 2. 部署NebulaGraph (三) to MAC 三、Nebula Graph Studio (一) 版本兼容性 (二) 原生安装 (三) Docker compose (四) 连接Nebula Gra…

mysql基础1sql分类

mysql基础 [rootvm ~]# docker run -itd -p 3306:3306 -e "MYSQL_ROOT_PASSWORD123456" mysql:5.7.26通用语法 1). SQL语句可以单行或多行书写&#xff0c;以分号结尾。 2). SQL语句可以使用空格/缩进来增强语句的可读性。 3). MySQL数据库的SQL语句不区分大小写…

面试算法-88-反转链表

题目 给你单链表的头节点 head &#xff0c;请你反转链表&#xff0c;并返回反转后的链表。 示例 1&#xff1a; 输入&#xff1a;head [1,2,3,4,5] 输出&#xff1a;[5,4,3,2,1] 解 class Solution {public ListNode reverseList(ListNode head) {if(head null || hea…

康托展开(以及相关例题和代码)

1.定义 康托展开是一个全排列到一个自然数的双射&#xff0c;常用于构建哈希表时的空间压缩。 康托展开的实质是计算当前排列在所有由小到大全排列中的顺序&#xff0c;因此是可逆&#xff08;划重点&#xff0c;要考的&#xff09;的。 当然了通俗易懂的来说的话&#xff0c…

2024年阿里云服务器价格查询系统,最新报价

2024年腾讯云服务器优惠价格表&#xff0c;一张表整理阿里云服务器最新报价&#xff0c;阿里云服务器网整理云服务器ECS和轻量应用服务器详细CPU内存、公网带宽和系统盘详细配置报价单&#xff0c;大家也可以直接移步到阿里云CLUB中心查看 aliyun.club 当前最新的云服务器优惠券…

java线上环境cpu飙升,排查策略。

定位过程&#xff1a; CPU飙升问题定位的一般步骤是&#xff1a; 首先通过top指令查看当前占用CPU较高的进程PID&#xff1b; 查看当前进程消耗资源的线程PID&#xff1a;top -Hp PID 通过print命令将线程PID转为16进制&#xff0c;根据该16进制值去打印的堆栈日志内查询&am…

牛客小白月赛89(A,B,C,D,E,F)

比赛链接 官方视频讲解&#xff08;个人觉得讲的还是不错的&#xff09; 这把BC偏难&#xff0c;差点就不想做了&#xff0c;对小白杀伤力比较大。后面的题还算正常点。 A 伊甸之花 思路&#xff1a; 发现如果这个序列中最大值不为 k k k&#xff0c;我们可以把序列所有数…

Prometheus 配置Basic auth认证

官方配置说明&#xff1a; Basic auth | Prometheus 一、生成密码加密串 Prometheus于2.24版本&#xff08;包括2.24&#xff09;之后提供Basic Auth功能进行加密访问&#xff0c;在浏览器登录UI的时候需要输入用户密码&#xff0c;访问Prometheus api的时候也需要加上用户密…

OpenHarmony开发自测试执行框架

OpenHarmony为开发者提供了一套全面的开发自测试框架OHA-developer_test&#xff0c;开发者可根据测试需求开发相关测试用例&#xff0c;开发阶段提前发现缺陷&#xff0c;大幅提高代码质量。 本文从基础环境构建&#xff0c;用例开发&#xff0c;编译以及执行等方面介绍OpenH…

Autosar MCAL配置——ADC

文章目录 前言一、创建Adc硬件单元二、创建、配置Adc通道1.根据电路原理图,有多少ADC采样引脚,就创建多少ADC采样通道。2.配置Adc通道3.配置ADC组4.配置ADC扫描组三、配置ADC通用设置前言 ADC,即Analogue Digital Converter缩写。简单来说,它是将输入的模拟信号转换为数字…