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模型的更多相关文章

  1. 高性能网络通信框架 HP-Socket

      HP-Socket 详细介绍 HP-Socket 是一套通用的高性能 TCP/UDP/HTTP 通信框架,包含服务端组件.客户端组件和Agent组件,广泛适用于各种不同应用场景的 TCP/UDP/ ...

  2. 专訪阿里陶辉:大规模分布式系统、高性能server设计经验分享

    http://www.csdn.net/article/2014-06-27/2820432 摘要:先后就职于在国内知名的互联网公司,眼下在阿里云弹性计算部门做架构设计与核心模块代码的编写,主要负责云 ...

  3. Netty高性能网络应用框架对标P7面试题分享v4.1.70.Final

    概述 **本人博客网站 **IT小神 www.itxiaoshen.com 定义 Netty官网 https://netty.io/ 最新版本为4.1.70.Final Netty是一个异步的.事件驱 ...

  4. nginx源代码分析--高性能server开发 常见的流程模型

    1.高性能server 对于高性能server对于.处理速度和占用空间小是典型特性.特别是当server经验C10K问题的时候(网络server在处理数以万计的client连接时.往往出现效率低下甚至 ...

  5. 在SQL Server中实现关系模型的阶梯到级别3的t -SQL DML

    在SQL Server中实现关系模型的阶梯到级别3的t -SQL DML 格雷戈里·拉森(Gregory Larsen),2017/08/02(第一次出版:2011 /11/09) 原文链接:http ...

  6. 在SQL Server中实现关系模型

    使用SQL Server的Transact-SQL(T-SQL)方言,此楼梯将为您提供如何使用SQL Server表中的数据的基本了解. DML是数据操作语言,是处理数据的语言的一个方面.它包括SEL ...

  7. TensorFire:WEB端的高性能神经网络框架

    TensorFire:WEB端的高性能神经网络框架 摘要: 近日,一种专门用于在网页内执行神经网络算法的JavaScript库——TensorFire引起了人们的关注,这种JavaScript库在浏览 ...

  8. 高性能NIO框架Netty-对象传输

    http://cxytiandi.com/blog/detail/17403 上篇文章高性能NIO框架Netty入门篇我们对Netty做了一个简单的介绍,并且写了一个入门的Demo,客户端往服务端发送 ...

  9. 基于Protobuf的分布式高性能RPC框架——Navi-Pbrpc

    基于Protobuf的分布式高性能RPC框架——Navi-Pbrpc 二月 8, 2016 1 简介 Navi-pbrpc框架是一个高性能的远程调用RPC框架,使用netty4技术提供非阻塞.异步.全 ...

随机推荐

  1. c# 递归异步获取本地驱动器下所有文件

    //获取所有驱动器 string[] drives = Environment.GetLogicalDrives(); foreach (string driver in drives) { Cons ...

  2. XINCLUDE

    前言 导入外部xml文档,类似于php的include,将外部定义的dtd引入当前文件,因为引入外部实体具有局限性,所以使用xinclude来引入 语法 导入外部文档: <xi:include ...

  3. 牛客练习赛9 F - 珂朵莉的约数

    题目描述 珂朵莉给你一个长为n的序列,有m次查询 每次查询给两个数l,r 设s为区间[l,r]内所有数的乘积 求s的约数个数mod 1000000007 输入描述: 第一行两个正整数n,m第二行一个长 ...

  4. ref和out的用法和区别。

    关于ref和out的用法和区别在网上已经有很多的解释,这里只不过是写下对于我而说比较容易理解的解释. ref和out都可以用来在函数中返回数据,类似于c++中指针. 参数 Ref Out 是否一定需要 ...

  5. T-sql 行转列,数据库查询分页

    1 USE [APS_Future_FT] 2 GO 3 /****** Object: StoredProcedure [dbo].[A_CrudePrice] Script Date: 2013/ ...

  6. intellij idea 中文 汉化包 韩梦飞沙

    韩梦飞沙  韩亚飞  313134555@qq.com  yue31313  han_meng_fei_sha 汉化包 百度云盘 下载地址: https://pan.baidu.com/s/1hs6B ...

  7. Codeforces 650 D. Zip-line

    $ >Codeforces \space 650 D. Zip-line<$ 题目大意 : 有一个长度为 \(n\) 的序列 \(h\) ,\(m\) 次询问,每一次询问求如果把序列中第 ...

  8. [BZOJ4311]向量(凸包+三分+线段树分治)

    可以发现答案一定在所有向量终点形成的上凸壳上,于是在上凸壳上三分即可. 对于删除操作,相当于每个向量有一个作用区间,线段树分治即可.$O(n\log^2 n)$ 同时可以发现,当询问按斜率排序后,每个 ...

  9. ( VIJOS )VOJ 1049 送给圣诞夜的礼品 矩阵快速幂

    https://vijos.org/p/1049   非常普通的矩阵快速幂... 但是我 第一次写忘了矩阵不能交换律... 第一二次提交RE直到看到题解才发现这道题不能用递归快速幂... 第三次提交成 ...

  10. 《深入理解Spark-核心思想与源码分析》(六)第六章计算引擎

    RDD是Spark对各类数据计算模型的统一抽象,被用于迭代计算过程以及任务输出结果的缓存读写. 在所有MapReduce框架中,shuffle是连接map任务和reduce任务的桥梁.shuffle性 ...