高性能server框架--I/O模型
socket在创建的时候默认是堵塞的。我们能够通过socket系统调用的第二个參数传递SOCK_NONBLOCK标志,或者通过fcntl系统调用的F_SETFL命令,将其设置为非堵塞的。
堵塞和非堵塞的概念能应用与全部文件描写叙述符。不不过socket,我们称堵塞的文件描写叙述符为堵塞I/O,非堵塞的文件描写叙述符为非堵塞I/O.
针对堵塞I/O运行的系统调用可能由于无法马上完毕而被操作系统挂起。直到等待的事件发生为止。比方,client通过connect向server发起连接时,connect将首先发送同步报文段给server,然后等待server返回确认报文段,假设server的确认报文段没有马上到达client,则connect调用将被挂起,直到client收到确认报文段并唤醒connect调用,socket的基础API中,可能被堵塞的系统调用包含acept send rev connect.
针对非堵塞I/O运行的系统调用则总是马上返回,而无论事件是否已经发生。假设事件没有马上发生,这些系统调用就返回-1。和出错的情况一样,此时我们必须依据errno来分情况,对accept send recv而言,事件未发生时errno通常被设置成EAGAIN或者EWOULDBLOCK(意思为期望堵塞),对于connect,errno则被设置为EINPROGRESS(意思为正在处理中)。
非常显然。我们仅仅有在事件已经发生的情况下操作非堵塞i/o(读写等),才干提高程序的效率,因此,非堵塞I/O通常要和其它I/O通知机制一起使用,比方I/O复用和SIGIO信号。
I/O复用是最经常使用两个的I/O通知机制,他指的是,应用程序通过I/O复用函数想内核注冊一组事件,内核通过I/O复用函数把当中就绪的事件通知给应用程序,Linux上经常使用的I/O复用函数是select、poll epoll_wait。
须要明确的是,I/O复函数本身是堵塞的,他们能提高程序效率的原因在于他们具有同一时候监听多个I/O事件的能力。
SIGIO信号也能够用来报告I/O事件。当目标文件 描写叙述符上有事件发生时,SIGIO信号的信号处理函数将被触发,我们也就能够在该信号处理函数中对目标文件描写叙述II符运行非堵塞I/O操作了。
从理论上说。堵塞I/O I/O复用和信号驱动I/O都是同步I/O模型,由于在这三种I/O模型中,I/O读写操作,都是在I/O事件发生之后,由应用程序完毕的,在POSIX规范所定义的异步I/O模型则不同。对于异步I/O而言,用户能够直接对I/O运行读写操作。这些操作告诉内核用户读写缓冲区的位置,以及I./O操作完毕之 后内核通知应用程序的方式。异步I/O的读写总是马上返回。而不论I/O是否堵塞,由于真正的读写操作已经由内核接管。也就是说。同步I/O模型要求用户代码自行运行I/O操作(将数据从内核缓冲区读入用户缓冲区,或将数据从用户缓冲区写入内核缓冲区),而异步I/O机制则由内核来运行I/O操作(数据在内核缓冲区和用户缓冲区之间的移动是由内核在“后台”完毕的)。你能够这么觉得,同步I/O向应用程序通知的是I/O就绪事件。异步I/O想应用程序通知的是I/O完毕事件。linux环境下,aio.h头文件里定义了函数提供了异步I/O支持。
总结
I/O模型 读写操作和堵塞阶段
堵塞I/O 程序堵塞与读写操作
I/O复用 程序堵塞于I/O复用系统调用。但可同一时候监听多个I/O事件,对I/O本身读写操作是非堵塞的
SIGIO信号 信号触发读写就绪事件,用户程序运行读写操作,程序没有堵塞阶段
异步I/O 内核运行读写并触发读写完毕事件,程序没有堵塞阶段
同一时候,在并发模型中也有同步/异步的方式。可是和这里的概念不同。
在I/O模型中,同步和异步区分的是内核向应用程序通知的是何种I/O事件(是就绪事件还是完毕事件),以及该由谁来完毕I/O读写(是应用程序还是内核),在并发模型中,同步指的是程序全然依照代码序列的顺序运行,异步值得是程序运行须要由系统事件来驱动,常见的系统事件包含中断。信号等。
高性能server框架--I/O模型的更多相关文章
- 高性能网络通信框架 HP-Socket
HP-Socket 详细介绍 HP-Socket 是一套通用的高性能 TCP/UDP/HTTP 通信框架,包含服务端组件.客户端组件和Agent组件,广泛适用于各种不同应用场景的 TCP/UDP/ ...
- 专訪阿里陶辉:大规模分布式系统、高性能server设计经验分享
http://www.csdn.net/article/2014-06-27/2820432 摘要:先后就职于在国内知名的互联网公司,眼下在阿里云弹性计算部门做架构设计与核心模块代码的编写,主要负责云 ...
- Netty高性能网络应用框架对标P7面试题分享v4.1.70.Final
概述 **本人博客网站 **IT小神 www.itxiaoshen.com 定义 Netty官网 https://netty.io/ 最新版本为4.1.70.Final Netty是一个异步的.事件驱 ...
- nginx源代码分析--高性能server开发 常见的流程模型
1.高性能server 对于高性能server对于.处理速度和占用空间小是典型特性.特别是当server经验C10K问题的时候(网络server在处理数以万计的client连接时.往往出现效率低下甚至 ...
- 在SQL Server中实现关系模型的阶梯到级别3的t -SQL DML
在SQL Server中实现关系模型的阶梯到级别3的t -SQL DML 格雷戈里·拉森(Gregory Larsen),2017/08/02(第一次出版:2011 /11/09) 原文链接:http ...
- 在SQL Server中实现关系模型
使用SQL Server的Transact-SQL(T-SQL)方言,此楼梯将为您提供如何使用SQL Server表中的数据的基本了解. DML是数据操作语言,是处理数据的语言的一个方面.它包括SEL ...
- TensorFire:WEB端的高性能神经网络框架
TensorFire:WEB端的高性能神经网络框架 摘要: 近日,一种专门用于在网页内执行神经网络算法的JavaScript库——TensorFire引起了人们的关注,这种JavaScript库在浏览 ...
- 高性能NIO框架Netty-对象传输
http://cxytiandi.com/blog/detail/17403 上篇文章高性能NIO框架Netty入门篇我们对Netty做了一个简单的介绍,并且写了一个入门的Demo,客户端往服务端发送 ...
- 基于Protobuf的分布式高性能RPC框架——Navi-Pbrpc
基于Protobuf的分布式高性能RPC框架——Navi-Pbrpc 二月 8, 2016 1 简介 Navi-pbrpc框架是一个高性能的远程调用RPC框架,使用netty4技术提供非阻塞.异步.全 ...
随机推荐
- c# 递归异步获取本地驱动器下所有文件
//获取所有驱动器 string[] drives = Environment.GetLogicalDrives(); foreach (string driver in drives) { Cons ...
- XINCLUDE
前言 导入外部xml文档,类似于php的include,将外部定义的dtd引入当前文件,因为引入外部实体具有局限性,所以使用xinclude来引入 语法 导入外部文档: <xi:include ...
- 牛客练习赛9 F - 珂朵莉的约数
题目描述 珂朵莉给你一个长为n的序列,有m次查询 每次查询给两个数l,r 设s为区间[l,r]内所有数的乘积 求s的约数个数mod 1000000007 输入描述: 第一行两个正整数n,m第二行一个长 ...
- ref和out的用法和区别。
关于ref和out的用法和区别在网上已经有很多的解释,这里只不过是写下对于我而说比较容易理解的解释. ref和out都可以用来在函数中返回数据,类似于c++中指针. 参数 Ref Out 是否一定需要 ...
- T-sql 行转列,数据库查询分页
1 USE [APS_Future_FT] 2 GO 3 /****** Object: StoredProcedure [dbo].[A_CrudePrice] Script Date: 2013/ ...
- intellij idea 中文 汉化包 韩梦飞沙
韩梦飞沙 韩亚飞 313134555@qq.com yue31313 han_meng_fei_sha 汉化包 百度云盘 下载地址: https://pan.baidu.com/s/1hs6B ...
- Codeforces 650 D. Zip-line
$ >Codeforces \space 650 D. Zip-line<$ 题目大意 : 有一个长度为 \(n\) 的序列 \(h\) ,\(m\) 次询问,每一次询问求如果把序列中第 ...
- [BZOJ4311]向量(凸包+三分+线段树分治)
可以发现答案一定在所有向量终点形成的上凸壳上,于是在上凸壳上三分即可. 对于删除操作,相当于每个向量有一个作用区间,线段树分治即可.$O(n\log^2 n)$ 同时可以发现,当询问按斜率排序后,每个 ...
- ( VIJOS )VOJ 1049 送给圣诞夜的礼品 矩阵快速幂
https://vijos.org/p/1049 非常普通的矩阵快速幂... 但是我 第一次写忘了矩阵不能交换律... 第一二次提交RE直到看到题解才发现这道题不能用递归快速幂... 第三次提交成 ...
- 《深入理解Spark-核心思想与源码分析》(六)第六章计算引擎
RDD是Spark对各类数据计算模型的统一抽象,被用于迭代计算过程以及任务输出结果的缓存读写. 在所有MapReduce框架中,shuffle是连接map任务和reduce任务的桥梁.shuffle性 ...