首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Linux】高级IO --- 多路转接,select,poll,epoll

2.有哪些IO模型?哪些模型是高效的? 1. IO模型分为五种,分别是阻塞式IO,非阻塞IO,信号驱动IO多路转接IO,异步IO。下面我们讲一个例子先来浅浅谈一下这5个模型IO的做法。...所以本文章主要来介绍多路转接这种IO模型,同时也会讲解阻塞和非阻塞IO,需要注意的是,实际项目中,最常用的就是阻塞IO,同时大部分的fd默认就是阻塞的,因为这种IO太简单了,越简单的东西往往就越可靠,代码编写也越简单...而多路转接相比前三种IO模型更为高效一些,因为他能够一次等待多个文件描述符,但这四种IO都有一个共同的特征,就是直接参与了IO的过程,这样的通信我们称之为同步通信,而异步IO是典型的异步通信,他将等待数据就绪的事情交给了内核来处理...select是我们学习的第一个多路转接IO接口,select只负责IO过程中等待的这一步,也就是说,用户可能关心一些sock上的读事件,想要从sock中读取数据,直接读取,可能recv调用会阻塞,等待数据到来...所以多路转接其实是把IO的过程分开来执行了,用多路复用接口来监视fd上的事件是否就绪,一旦就绪就会立马通知上层,让上层调用对应的接口进行数据的处理,等待和数据拷贝的工作分开执行,这样的IO效率一定是高的

22030
您找到你想要的搜索结果了吗?
是的
没有找到

多路 io 转接模型 selectpoll

多路io转发服务器模型也是为了解决大并发多客户端场景下的问题,比多进程、多线程开销要少。...多进程多线程常规情况下都是使用 accept 或 read 函数在阻塞等接收客户端发送过来的数据,而多路io模型则是提供了一个系统函数,该函数负责阻塞判断各路被监控的文件描述符是否有数据读取或写入操作,...accept 或 read 去直接处理从而不会阻塞,系统函数可能会同时返回多个有数据的文件描述符等待后面的代码处理,所以效率上要比多进程和多线程同时只在一个位置阻塞获取数据效率要高一些,下面就介绍一下多路...io 模型 select 和 poll,poll 模型较 select 模型还存在一些优势,在本文后面将介绍。

24110

IO多路转接之select

本文分享的是IO多路转接中的select,其中包括select函数如何去使用,以及使用相关代码实现客户端向服务端发送消息的服务,从而更好地理解多路转接的select。...多路转接 多路转接IO模型的一种,这种IO模型通过select函数进行IO等待,并且select函数能够同时等待多个文件描述符的就绪状态,单个文件描述符的等待与阻塞IO类似。...select 系统提供select函数来实现多路复用输入/输出模型。select系统调用是用来让我们的程序监视多个文件描述符的状态变化的。...代码简单实现多路转换 使用select实现一个简单服务器,客户端可以向服务端发送消息,服务端读取数据。 代码思路:代码分五步: ①创建监听套接字,端口号,绑定,进入监听状态一系列动作。...fd_array[i] = -1; } // 不会在这里进行accept,accept的本质叫做通过listen_sock获取新链接 //accept是阻塞式等待 //站在多路转接的视角

24340

详解IO多路转接模型:select & poll & epoll

多路转接 多路转接IO模型的一种,这种IO模型通过select、poll或者epoll进行IO等待,可以同时等待多个文件描述符,当某个文件描述符的事件就绪,便会通知上层处理对应的事件。...I/O多路转接之select 了解select的基础理论 分享的流程是:先介绍什么是select、然后介绍select系统调用,接着了解select执行过程。 什么是select?...I/O多路转接之poll 分享流程:了解poll的接口,从而了解poll相对于select的好处,接着将上面的基于select的tcp服务器的代码改编成基于poll的服务器,最后总结一下poll的缺点...I/O多路转接之epoll 分享流程:先初识epoll,然后了解一下epoll的接口,然后结合接口调用,理解epoll的原理,接着基于epoll实现简单的TCP服务器。...它几乎具备了之前所说的一切优点,被公认为Linux2.6下性能最好的多路I/O就绪通知方法。

52140

详解IO多路转接之poll&epoll

I/O多路转接之poll 操作流程: 定义监控的描述符事件结构体数组,将需要监控的描述符以及时间标识信息,添加到数组的各个节点中 发起调用开始监控,将描述符事件结构体数组,拷贝到内核中进行轮询遍历判断...I/O多路转接之epoll 操作流程: 在内核中创建epool句柄epollevent结构体(这个结构体包含很多信息,红黑树+双向链表) 发起调用对内核中的epollevent结构添加/删除/修改所监控的描述符监控信息...返回给用户就绪描述符的事件结构体信息 进程直接对就绪的事件结构体中的描述符成员进行操作即可 接口信息 1.创建epoll句柄 int epoll_create(int size//创建epoll句柄 //size:在linux2.6.2...当某一进程调用epoll_create方法时,Linux内核会创建一个eventpoll结构体,这个结构体中有两个成员与epoll的使用方式密切相关. struct eventpoll{ ....具体要根据需求和场景特点来决定使用哪种IO模型.

47920

Linux IO多路复用模型

Linux IO多路复用模型 什么是流 什么是IO操作 阻塞与非阻塞模型 阻塞 解决阻塞死等待的办法 办法一:非阻塞、忙轮询 办法二:select 办法三:epoll Select和Poll模式 Epoll...使用epoll编程主流程骨架 epoll的触发模式 水平触发(LT) 边缘触发(ET) 简单的epoll服务器(C语言) Linux网络Server的N种并发模型 模型一、单线程Accept(无IO复用...) 模型二、单线程Accept+多线程读写业务(无IO复用) 模型三、单线程多路IO复用 模型四、单线程多路IO复用+多线程读写业务(业务工作池) 模型五、单线程IO复用+多线程IO复用(链接线程池)...---- 模型三、单线程多路IO复用 (1) 模型结构图 (2) 模型分析 ① 主线程main thread创建listenFd之后,采用多路I/O复用机制(如:select、epoll)进行IO...---- 模型五(进程版)、单进程多路I/O复用+多进程多路I/O复用(进程池) (1) 模型结构图 (2) 模型分析 与五、单线程IO复用+多线程IO复用(链接线程池)无大差异。

73120

LinuxIO多路复用机制

,对 CPU 消耗比较大,所以才有了我们后面的 IO 多路复用。...select 多路复用 IO 模型 先解释一个Linux中文件描述符的概念,通过文件描述符,可以找到文件指针,从而进入打开文件表,文件表里有很多关于文件的相关信息。...关于LinuxIO多路复用模型还有 poll 和 epoll ,这里说一下它们之间的区别,poll 可监视的 IO数量大于 select,而 epoll 和其他两个函数的区别就是不会轮询文件描述符来操作...IO,当一个IO完毕就直接通知刷新,而不是一直轮询判断可读写的状态来刷新,简单的说,epoll 只会刷新已经成功的 IO,而其他两个函数判断 IO 是否已成功是用轮询的方式,细心的朋友会发现,我们的这个...IO 多路复用好像也没有比阻塞或非阻塞 IO 模型强到哪去,而且还要往函数里添加 socket 监听回调,IO 多路复用的核心就在于同一时刻一个逻辑流也就是一个线程可以监听操作多个 IO,而其他 IO

1.2K20

IO多路复用

四、多路复用IO (IO multiplexing) 当用户进程调用了select,那么整个进程会被block,而同时,kernel会“监视”所有select负责的socket,当任何一个socket...很多操作系统提供了更为高效的接口, 如linux提供了epoll,BSD提供了kqueue,Solaris提供了/dev/poll,…。...七、selsectors模块 这三种IO多路复用模型在不同的平台有着不同的支持,而epoll在windows下就不支持,好在我们有selectors模块,帮我们默认选择当前平台下最合适的 1 #服务端...多路复用(select) select检测的是哪个套接字准备好了(检测的时候等待了,变成阻塞了) select之所以比阻塞IO好,就是因为select可以检测多个套接字 多个链接下select才能发挥它的优势...但是你的套接字特别多,你怎么知道哪个好了呢,那么就得用循环去遍历一下 那么如果特别多的时候,效率也就不咋高了 eppol:只支持linux系统(就是为了解决select效率低的问题) eppol比pool

51330

IO多路复用

1、“I/O多路复用”这个坑爹翻译可能是这个概念在中文里面如此难理解的原因; 2、I/O多路复用,即:I/O multiplexing,这里面的 multiplexing 指的其实是在单个线程通过记录跟踪每一个...epoll IO多路复用 epoll代理的原理是这样的: 当连接有I/O流事件产生的时候,epoll就会去告诉进程哪个连接有I/O流事件产生,然后进程就去处理这个进程。如此,多高效!...可是epoll 有个致命的缺点,只有linux支持。于是其他的平台实现类型的多路复用,比如BSD上面对应的是kqueue, win下对应的iocp。...Nginx 异步,非阻塞,IO多路复用 Nginx 这样出众,正是他采用了异步,非阻塞,IO多路复用。 Nginx之前是单进程的。看下他的进程。1个master进程,2个work进程。...这就是非阻塞和IO多路复用。而一旦上游服务器返回了,就会触发这个事件,worker才会来接手,这个request才会接着往下走。这就是异步回调。

52320

IO 多路复用

战略上藐视技术,战术上重视技术 为了讲多路复用,当然还是要跟风,采用鞭尸的思路,先讲讲传统的网络 IO 的弊端,用拉踩的方式捧起多路复用 IO 的优势。...IO 多路复用 为每个客户端创建一个线程,服务器端的线程资源很容易被耗光。 ? 当然还有个聪明的办法,我们可以每 accept 一个客户端连接后,将这个文件描述符(connfd)放到一个数组里。...如果你想继续深入了解 epoll 的底层原理,推荐阅读飞哥的《图解 | 深入揭秘 epoll 是如何实现 IO 多路复用的!》...,从 linux 源码级别,一行一行非常硬核地解读 epoll 的实现原理,且配有大量方便理解的图片,非常适合源码控的小伙伴阅读。 后记 大白话总结一下。...后来操作系统又发现这个场景需求量较大,于是又在操作系统层面提供了这样的遍历文件描述符的机制,这就是 IO 多路复用。

89220

IO多路复用丶基于IO多路复用+sock

一丶IO多路复用   IO多路复用指:通过一种机制,可以监视多个描述符,一旦某个描述符就绪(一般是读就绪或者写就绪),能够通知程序进行相应的读写操作   IO多路复用作用:     检测多个socket...select.select       select.epoll   Python中有一个select模块,其中提供了:select丶poll丶epoll三个方法,分别调用系统的select,poll,epoll从而实现IO...多路复用   注意: 网络操作丶文件操作丶终端操作等均属于IO操作,对于windows只支持socket操作,其他系统支持其他IO操作,但是无法检测普通文件操作,自动上次读取是否已经变化 二丶基于IO多路复用...或执行时间过长就会被迫交出CPU权限,切换其他线程运行)     2.单线程内开启进程,一旦遇到IO,就会从应用程序级别(而非操作系统)控制切换,以此来提升效率(非IO操作的切换与效率无关)   对比操作系统控制线程的切换...操作自动切换到其它协程(如何实现检测IO,yield,greenlet都无法实现,就用到了gevent模块(select机制)) Greenlet模块   安装:pip3 install greenlet

71020

IO模式和IO多路复用

Linux 的缓存 I/O 机制中,以write为例,数据会先被拷贝进程缓冲区,在拷贝到操作系统内核的缓冲区中,然后才会写到存储设备中。 缓存I/O的write: ?...阻塞 I/O(blocking IO)   -- 非阻塞 I/O(nonblocking IO)   -- I/O 多路复用( IO multiplexing)   -- 信号驱动 I/O( signal...2.3 I/O多路复用     I/O多路复用实际上就是用select, poll, epoll监听多个io对象,当io对象有变化(有数据)的时候就通知用户进程。...当然具体区别我们后面再讨论,现在先来看下I/O多路复用的流程: ?...多路复用的本质是用select、poll、epoll(系统底层提供的)来监听socket对象内部是否有变化 49 # select 是在Win和Linux中都支持额,相当于系统内部维护了一个for循环,

74930
领券