马哥教育网络第20期—IO类型与IO模型

IO类型与IO模型

IO类型

同步与异步(synchronous,asynchronous):关注消息通知机制

同步:进程发出系统调用之后,不会立即有返回信息,但是一旦有返回信息,则一定是最终结果.
异步:进程发出系统调用之后,会有立即返回结果,但不是最终的结果,当内核处理完成之后,内核通过通知机制通知进程,该系统调用已完成.

阻塞与非阻塞(blocking,nonblocking):关注系统调用完成时,调用者的状态

阻塞:调用者在返回结果之前,一直处于被挂起状态,直到有调用结果返回时才能继续工作.
非阻塞:调用者在调用结果返回之前,并不会被挂起,即系统调用这个动作不会阻塞调用者.

IO模型的分类

  • 阻塞I/O

  • 非阻塞I/O

  • 复用I/O

  • 事件驱动I/O

  • 异步I/O

自己画的

37.png

画完之后参考网上的

42.png

阻塞I/O模型

38.png

 当用户进程发起系统调用之后,在内核还没有完成该调用任务时,进程会一直被挂起,直到内核将调用完成(内核将数据从磁盘取出到内核内存做处理,处理完之后在将数据转移至进程内存),这时进程才可以继续工作.

非阻塞I/O模型

39.png

 当用户进程发起系统调用之后,该进程不会被挂起,先是处于盲等待状态,反复向内核确认该调用是否完成,当内核将数据从磁盘取出到内核内存处理完成时,该进程会被挂起,并且内核会将处理的数据转移至进程内存,这时进程来能继续工作(该进程在数据从内核内存转移至进程内存时,是被挂起).

复用I/O模型

40.png

 当用户进程发起系统调用之后,该进程可以发送多个处理请求交给内核处理,select,poll,epoll都是IO多路复用的机制。I/O多路复用就是通过一种机制,一个进程可以监视多个描述符,一旦某个描述符就绪(一般是读就绪或者写就绪),能够通知程序进行相应的读写操作。但select,poll,epoll本质上都是同步I/O,因为他们都需要在读写事件就绪后自己负责进行读写,也就是说这个读写过程是阻塞的,而异步I/O则无需自己负责进行读写,异步I/O的实现会负责把数据从内核拷贝到用户空间.

事件驱动I/O模型

 当用户进程发起系统调用之后,内核会立即返回一个信号,表示该调用已经收到,接下来该进程可以去处理其他工作,当内核将数据在内核内存中准备好之后,就会通知该进程,进程这个时候就会被挂起,等待内核将数据转移至进程内存,进程才可以继续工作.

异步I/O模型

41.png

 当用户进程发起系统调用之后,内核会立即返回一个信号,表示该调用已经收到,进程可以自由活动,接下来内核处理数据,当内核将数据转移至进程内存之后,会通知该进程数据已经准备好,此时进程只要去进程内存接着处理就OK.

原创文章,作者:nice_neo_linux,如若转载,请注明出处:http://www.178linux.com/19860

(1)
nice_neo_linuxnice_neo_linux
上一篇 2016-06-26
下一篇 2016-06-26

相关推荐

  • RAID概述

    1、引言 RAID全称Redundant Arrays of Inexpensive Disks / Redundant Arrays of Independent Disks,即独立冗余磁盘阵列。RAID可以通过相关技术(软件/硬件),将多个较小的磁盘整合成为一个较大的磁盘整体,而且能从某些方面提高数据的读写及数据保护。RAID分为不同…

    Linux干货 2016-12-24
  • 详解 /etc/inittab 文件

    当内核初始化后,就会启动第一个进程 init,init进程会进行一系列的系统初始化工作,init是根据什么来进行初始化的? init 会读取/etc/inittab文件(针对CentOS 5 系列),执行里面的内容来进行初始化工作,这个文件是一定的格式。 获取inittab文件的帮助,输入 man inittab 命令 过滤掉空白行和以#号开始的行,内容如下…

    Linux干货 2015-03-10
  • 马哥教育21期网络班—第14周课程+练习——>iptables 练习

    系统的INPUT和OUTPUT默认策略为DROP; iptables -P INPUT DROP iptables -P OUTPUT DROP [root@localhost ~]# iptables -L -n  Chain INPUT…

    Linux干货 2016-10-24
  • 优云软件数据专家最佳实践:数据挖掘与运维分析

    这份研究报告,作者是优云软件数据专家陈是维,在耗时1年时间制作的一份最佳实践,今天和大家分享下,关于《数据采矿和运维分析》,共同探讨~ 数据挖掘(Data Mining)是从大量数据中提取或“挖掘”知识。 广义数据挖掘:数据挖掘是从存放在数据库、数据仓库或其它信息库中的大量数据挖掘有趣知识的过程。 数据挖掘技术侧重:1)概率与数理统计 2)数据库技术 3)人…

    大数据运维 2016-07-16
  •         linux 文件颜色的含义:         蓝色代表目录         绿色代表可执行文件 &nbs…

    Linux干货 2016-12-05
  • 马哥教育网络班21期+第一周课程练习

    1,描述计算机的组成及其功能。 2.按系列罗列linux的发行版,并描述不同发行版之间的练习与区别。 3.描述linux的哲学思想,并按照自己的理解对其进行解释性描述。 1.       一切皆文件,计算机中所有的文件目录,        包括计算机的硬件设备显示为文件格式。 2…

    Linux干货 2016-07-07