美文网首页
linux下五种io编程模型

linux下五种io编程模型

作者: 潋濛 | 来源:发表于2017-10-18 16:32 被阅读0次

1.阻塞io,linux下默认所有的io都是阻塞的,

当发起io操作时,程序阻塞,直到io完成才会返回。浪费cpu的资源。

2非阻塞io

当发起io操作后,程序会立即返回,之后程序不断轮询,判断io是否就绪。这种情况下的轮训就是傻轮询,无论io是否就绪,会一直去问。但是好的一点是,在while的轮询过程中可以做一些其它的事情。但是这种非阻塞io往往需要配合多线程达到高效率。因为服务器往往有多个客户端的连接,单一线程要实现对多个连接的管理,往往需要通过队列,对多个socket进行管理,这对用户来说往往很困难(有几个人能手写linux内核对select或epoll的底层实现?),而多线程的切换又是十分消耗系统资源的,所以非阻塞io+多线程实现高性能服务器,往往效果也不是很好。

3.io多路复用(select/epoll)(reactor)

多线程是十分耗费系统资源的,那么我们自然而然就想到能否用单线程实现对多个客户端socket的管理,在上面提到如果在用户态完成这个任务是比较困难的,但是庆幸的是linux内核帮我们实现了这个复杂的操作,典型的两种是select和epoll.二者的区别

select

用一个eventloop队列去管理多个socket,没有io时,select阻塞挂起,但是它只知道有数据到达,并不知道是那个fd(socket)的,所以需要遍历所有的fd,找出真正被触发的socket,执行其对应的处理函数。

epoll

epoll同样维护了一个轮询的eventloop,但是不同的是它在客户端有数据到达时,会被显示的告知是哪几个socket被触发,因此不需要再用o(n)的时间复杂度去轮询,所以性能很高。epoll是单线程异步io,但是这种异步并不是那么纯,因为数据。

4.信号驱动

不常用

5.异步io(被动告知异步)

没有阻塞,就是当数据到达时,利用中断机制切换到用户态处理。io多路复用需要主动轮询,用户自己将数据从内核态地址空间拷贝到用户态,而异步io会将数据的同步自动完成,用户进程只需要去读取数据即可。

异步io和io多路复用区别是异步io是事情做完了你通知我一声,而io多路复用是事情可以做的话你告诉我一声,我去做。

io多路复用会阻塞用户socket,而异步io不会阻塞用户线程。

io多路复用是同步io,因为用户态还要去轮询看看哪些事件可以就绪执行,(虽然操作系统已经触发了对应事件,但是用户还得去轮询队列中一遍遍查看)

异步io(异步非阻塞)用户进程不会被阻塞。

阻塞:调用立即返回

非阻塞:调用不返回

同步: 我自己去问消息是否完成。

异步:主动告知我消息是否完成。

相关文章

  • 【Netty开发指南】搭稳Netty开发的地基

    Linux网络编程5种IO模型 根据UNIX网络编程对于IO模型的分类,UNIX提供了5种IO模型,分别是 阻塞I...

  • 高并发服务器IO模型

    高并发服务器 IO 模型一、 什么是 IO?二、 IO 的 5 种模型三、Linux 并发网络编程模型四、sele...

  • linux select/epoll

    一、Unix/Linux网络IO模型在经典的Unix网络编程中,总结出了5种不同的网络IO模型,分别是阻塞式IO,...

  • Linux编程学习笔记 | Linux IO学习[2] - 标准

    在上一篇Linux编程学习笔记 | Linux IO学习[1] - 文件IO中,我总结了Linux下的文件IO。文...

  • linux下五种io编程模型

    1.阻塞io,linux下默认所有的io都是阻塞的, 当发起io操作时,程序阻塞,直到io完成才会返回。浪费cpu...

  • Netty理论一:Java IO与NIO

    1、Linux IO模型 1、《Unix网络编程》把I/O模型分成五类阻塞式I/O模型:整个过程都是阻塞的——BI...

  • 1.Nette入门第一章——IO演进

    1. IO 基础 1.1. linux网络IO模型 阻塞IO模型 非阻塞IO模型 IO多路复用模型(NIO) 信...

  • Linux IO与网络编程模型

    术语概念描述: IO有内存IO、网络IO和磁盘IO三种,通常我们说的IO指的是后两者。 阻塞和非阻塞,是函数/方法...

  • 2018-07-03

    Netty实践与NIO原理 一、阻塞IO与非阻塞IO Linux网络IO模型(5种) (1)阻塞IO模型 所有文件...

  • 2、Linux IO模型

    下图是Linux处理IO调用的流程图: Linux IO模型分为5种: 阻塞IO 非阻塞IO IO复用 事件驱动I...

网友评论

      本文标题:linux下五种io编程模型

      本文链接:https://www.haomeiwen.com/subject/dtjeuxtx.html