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 ...
随机推荐
- 【转】WPS word 文档中的插入对象 为什么打不开
点击桌面左下角开始按钮--所有程序,找到wps office文件夹--wps office工具--配置工具--高级--兼容设置,否选兼容第三方软件.
- css中有三个显示和隐藏的单词比较常见,display visibility 和 overflow我们需要区分开来
display display 设置或检索对象是否及如何显示 display: none 隐藏对象与它相反的是display:block 除了转换为块级元素之外,同时还有显示元素的意思 特点: 隐藏之 ...
- Sping4之注入参数
Spring的依赖注入不仅可以注入基本类型,也可以注入包括model,list等等类型 package com.hongcong.test; import org.springframework.co ...
- Arthas的基础学习
下载与安装 wget https://alibaba.github.io/arthas/arthas-boot.jar java -jar arthas-boot.jar 启动 查看启动的帮助信息: ...
- 有关Linux ipv6模块加载失败的问题
有关Linux ipv6模块加载失败的问题 同事一个SUSE11sp3环境配置ipv6地址失败,提示不支持IPv6,请求帮助,第一反应是应该ipv6相关内核模块没有加载. 主要检查内容: ...
- python day08 文件操作
2019.4.8 S21 day08笔记总结 一.进制 对于计算机而言无论是文件存储 / 网络传输数据本质上都是:二进制(010101010101),如:电脑上存储视频/图片/文件都是二进制: QQ/ ...
- python之科学函数课——Numpy
一般来讲,数据都是由行列表示的,也就是矩阵,类似于Excel表格一样的东西. 首先我们学习一下Numpy,装好anaconda之后默认是装好的,下面是numpy的一些函数库:Numpy是科学计算库,是 ...
- C++读取与保持图片
#include<iostream> using namespace std; void main(void) { //保存输入图像文件名和输出图像文件名 ]; ]; //图像数据长度 i ...
- Python 3之Django2部署(centos7+nginx+python3+django2.0)
前置工具,系统为centos7.5,为了方便管理,可以安装宝塔免费版本 首先, yum install -y wget && wget -O install.sh http://dow ...
- string转可空类型
string类型转可空类型 string.IsNullOrEmpty(str) ? (int?)null : int.Parse(str) 此处要注意将null转为可空的类型才可以,不然会报错