linux五种I/O模型
1.基本概念
1.1同步和异步
同步和异步关注的是消息通信机制
1.1.1同步
所谓同步,就是在发出一个调用时,在没有得到结果之前,调用就不返回,一直在等,但是一旦调用返回,就能得到返回值。
1.1.2异步
异步与同步相反,调用在发出之后,这个调用就直接返回了,调用者不能立刻得到结果,而是在调用彻底完成后,通过状态、通知和回调来通知调用者
1.1.3举例
你打电话问书店老板有没有《计算机网络》这本书,如果是同步通信机制,书店老板会说,你稍等,”我查一下",然后开始查啊查,等查好了(可能是5秒,也可能是一天)告诉你结果(返回结果)。而异步通信机制,书店老板直接告诉你我查一下查好了打电话给你,然后直接挂电话了(不返回结果)。然后查好了,他会主动打电话给你。在这里老板通过“回电”这种方式来回调。
1.2阻塞与非阻塞
阻塞和非阻塞关注的是程序在等待调用结果(消息,返回值)时的状态
1.2.1阻塞
阻塞调用是指调用结果返回之前,当前线程会被挂起(即线程暂停运行),调用线程只有在得到结果之后才会返回;对于同步调用来说,很多时候当前线程还是激活的,只是从逻辑上当前函数没有返回而已
1.2.2非阻塞
非阻塞调用指在不能立刻得到结果之前,该调用不会挂起当前线程
1.2.3举例
还是上面的例子,你打电话问书店老板有没有《分布式系统》这本书,你如果是阻塞式调用,你会一直把自己“挂起”,直到得到这本书有没有的结果,如果是非阻塞式调用,你不管老板有没有告诉你,你自己先一边去玩了, 当然你也要偶尔过几分钟检查一下老板有没有返回结果。在这里阻塞与非阻塞与是否同步异步无关,跟老板通过什么方式回答你结果无关
1.3一个输入操作(input)的两个阶段
1)等待数据准备好
2)内核向进程复制数据
2.阻塞式I/O模型

1)简介:进程会一直阻塞,直到数据被拷贝到进程的缓冲区
2)进程在从调用recvfrom开始到它返回的整段时间内是被阻塞的。recvfrom成功返回后,进程开始处理数据
3.非阻塞式I/O模型

1)简介:非阻塞IO通过进程不断地调用IO函数,每次调用IO函数若没有数据可返回,则内核转而立即返回一个错误,直至数据准备好,此时将数据拷贝到进程的缓冲区
2)前三次调用recvfrom时没有数据可返回,因此内核每次都立即返回一个EWOULDBLOCK错误;第四次调用recvfrom时已有数据报准备好,它被拷贝到应用进程缓冲区,recvfrom于是成功返回,接着处理数据
3)不断调用IO函数的过程是非阻塞的,数据拷贝的过程是阻塞的
4)进程对一个非阻塞描述符循环调用IO函数时,称之为轮询;轮询往往耗费大量CPU时间
4.I/O复用模型
1)简介:I/O复用会调用select、poll、epoll函数,这三个函数也会使进程阻塞,但是和阻塞I/O所不同的的,这三个函数可以可以同时侦听多个套接口,当有某个套接口可读时,才真正调用recvfrom
2)使用I/O复用的优势在于可以同时等待多个套接口(在多线程中使用阻塞I/O模型与I/O复用模型类似,此时,I/O多路复用的最大优势是系统开销小)
适用场景
1)当一个客户同时处理多个套接字时,而这种情况是可能的,但很少出现
2)如果一个TCP服务器既要处理监听套接口,又要处理已连接套接口,一般也要用到I/O复用
3)如果一个服务器要处理多个服务或多个协议,如:即要处理TCP,又要处理UDP,一般要使用I/O复用
5.信号驱动式I/O模型
1)简介:让内核在数据准备就绪时发送SIGIO信号通知进程
2)通过sigaction安装一个信号处理函数,当数据准备好时,内核就为该进程产生一个SIGIO信号,随后进程将在信号处理函数中调用recvfrom处理数据
3)这种模型的优势在于等待数据期间,进程不被阻塞
5.异步I/O模型
1)简介:内核启动某个操作,内核在数据拷贝到进程缓冲区完成后,再通知进程
2)异步I/O模型与信号驱动式I/O模型的主要区别:信号驱动I/O是由内核通知进程何时启动一个I/O操作,而异步I/O模型是由内核通知进程I/O操作已经完成了
6.同步I/O模型和异步I/O模型
POSIX标准定义:
1)同步I/O模型:I/O操作将导致进程阻塞的模型,就叫同步I/O模型
2)异步I/O模型:I/O操作不导致进程阻塞的模型,就叫异步I/O模型
3)根据上述定义,前4种模型——阻塞I/O模型、非阻塞I/O模型、I/O复用模型和信号驱动I/O模型都是同步I/O模型,因为其中真正的I/O操作(recvfrom)都将阻塞进程;只有异步I/O模型与POSIX定义的异步I/O相匹配
linux五种I/O模型的更多相关文章
- Linux五种I/O模型性能分析
转载自:http://blog.csdn.net/jay900323/article/details/18141217/ socket阻塞与非阻塞,同步与异步 作者:huangguisu 1. 概念理 ...
- Linux五种IO模型性能分析
1. 概念理解 在进行网络编程时,我们常常见到同步(Sync)/异步(Async),阻塞(Block)/非阻塞(Unblock)四种调用方式: 同步: 所谓同步,就是在发出一个功能调用时, ...
- [转载] Linux五种IO模型
转载:http://blog.csdn.net/jay900323/article/details/18141217 Linux五种IO模型性能分析 目录(?)[-] 概念理解 Lin ...
- 网络通信 --> Linux 五种IO模型
Linux 五种IO模型 聊聊Linux 五种IO模型
- []转帖] 浅谈Linux下的五种I/O模型
浅谈Linux下的五种I/O模型 https://www.cnblogs.com/chy2055/p/5220793.html 一.关于I/O模型的引出 我们都知道,为了OS的安全性等的考虑,进程是 ...
- Linux五种IO模型(同步 阻塞概念)
Linux五种IO模型 同步和异步 这两个概念与消息的通知机制有关. 同步 所谓同步,就是在发出一个功能调用时,在没有得到结果之前,该调用就不返回.比如,调用readfrom系统调用时,必须等待IO操 ...
- Windows五种IO模型性能分析和Linux五种IO模型性能分析
Windows五种IO模型性能分析和Linux五种IO模型性能分析 http://blog.csdn.net/jay900323/article/details/18141217 http://blo ...
- (转载) Linux五种IO模型
转载:http://blog.csdn.net/jay900323/article/details/18141217 Linux五种IO模型及分析 目录(?)[-] 概念理解 Linux下 ...
- I/O模型之一:Unix的五种I/O模型
目录: <I/O模型之一:Unix的五种I/O模型> <I/O模型之二:Linux IO模式及 select.poll.epoll详解> <I/O模型之三:两种高性能 I ...
随机推荐
- webservice 教程
https://ke.qq.com/webcourse/index.html#cid=28875&term_id=100182700&taid=800324205965515& ...
- java mybatis后台判断表是否存在mysql
<select id="isTableExist" parameterType="string" resultType="int"&g ...
- jq 获取下一个兄弟原素 下拉箭头旋转
$('.weui-cells__title').on("click", function(e,rr){ isshow=$(this).attr('isshow') if(issho ...
- windows 下用命令来操作定时任务
cmd下定时执行命令可以使用 at 命令 或者 schtasks命令.at 语法:at +时间+运行程序schtasks语法:schtasks /creat /tn 设定定时运行的名字 /tr “运行 ...
- C语言典型编程3
关于C的一些小而精的编程,适合希望提升编程能力的初学者学习:关键编程也就几句,但思维可以迁移到其他编程语言.同一问题,算法多种. //判断三角形类型#include<stdio.h>mai ...
- css的继承和层叠
标签(空格分隔): css css称为层叠样式表,CSS有两大特性:继承性和层叠性,本章简单介绍一下继承性: 继承性: 定义:继承就是给父及设置了一些属性,子级继承了父及的该属性,这就是我们的css的 ...
- 解题(Solution -4Sum)
Given an array S of n integers, are there elements a, b, c, and d in S such that a + b + c + d = tar ...
- java api 批量数据库操作
Statement.class:executeBatch() implement interface: PreparedStatement implement class: JdbcOdbcPrepa ...
- Apache和Nginx运行原理解析
Web服务器 Web服务器也称为WWW(WORLD WIDE WEB)服务器,主要功能是提供网上信息浏览服务. 应用层使用HTTP协议. HTML文档格式. 浏览器统一资源定位器(URL). Web服 ...
- python3作业:模拟登录
__author__ = "bin007" customer = {}#存储用户信息#处理用户信息文件try: with open('login.txt','r',encoding ...


