马哥教育网络第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 22:40
下一篇 2016-06-26 22:41

相关推荐

  • 命令的查看帮助 和 命令行的历史

    命令的查看 分内部命令 和外部命令  查看外部命令 可用 man command–help info  查看内部命令 可用 help command man 帮助是 使用最频繁的 命令查看 而 man 又有很多选项 如下    man – format and display the on-li…

    Linux干货 2016-08-12
  • M20用户和组练习题和作业

    1、创建用户gentoo ,附加组为bin 和root ,默认shell为/bin/csh ,注释信息为"Gentoo Distribution"  useradd gentoo -G bin,boot -s /bin/csh -c "Gentoo Distribution" 2 、创建下面的用户、组和组成员…

    Linux干货 2016-08-03
  • Xtrabackup进行MySQL备份

    使用Xtrabackup进行MySQL备份 一、安装 1、简介 Xtrabackup是由percona提供的mysql数据库备份工具,据官方介绍,这也是世界上惟一一款开源的能够对innodb和xtradb数据库进行热备的工具。 特点: (1)备份过程快速、可靠; (2)备份过程不会打断正在执行的事务; (3)能够基于压缩等功能节约磁盘空间和流量; (4)自动…

    Linux干货 2017-02-20
  • 学习宣言

     学习计划:参考N24学习时间与线路图,尽最大努力完成。 目标:学习好Linux,提升自我价值,找一份待遇好的工作。 宣言:每一次轻易的放弃,都是人生的一处败笔,为了梦想,加油!

    Linux资讯 2016-10-26
  • 文件的元数据信息有哪些,分别表示什么含义,如何查看?如何修改文件的时间戳信息。

    1)文件的元数据信息及查看 文件的数据分两种:一种元数据,既属性数据;一种就是数据本身;可使用stat命令查看文件的元数据: 例如: ]# stat /etc/passwd 文件:"/etc/passwd" 大小:2483 块:8 IO 块:4096 普通文件 设备:fd00h/64768d Inode:136755684 硬链接:1 权…

    Linux干货 2016-11-06
  • CentOS7 实现网卡绑定

    Bonding ;理念 将多块网卡绑定同一IP地址对外提供服务,可以实现高可用 或者负载均衡。直接给两块网卡设置同一IP地址是不可以的 。通过bonding,虚拟一块网卡对外提供连接,物理网卡的 被修改为相同的MAC地址 banding工作模式 Mode 0 (balance-rr) 轮转(Round-robin)策略: 从头到尾顺序的在每一个slave 接…

    2017-12-19