上一篇文章 主要分析了 Linux 原生 AIO 的原理和使用,而这篇要介绍的是 Linux 原生 AIO 的实现过程。...所以,我们可以通过分析这三个函数的实现来理解 Linux 原生 AIO 的实现。 Linux 原生 AIO 实现在源码文件 /fs/aio.c 中。...调用 aio_setup_ring 函数初始化环形缓冲区。...函数 if (file->f_op->aio_read) ret = file->f_op->aio_read(req, buf, iocb->aio_nbytes...不同的文件系统,其 aio_read 方法的实现不一样,如 Ext3 文件系统的 aio_read 方法会指向 generic_file_aio_read 函数。
POSIX AIO 第一套被称作POSIX AIO。顾名思义,这套接口是POSIX标准规定的。这套AIO的接口的定义可以参考这里。...Linux AIO Linux中的另外一套AIO接口被称为Linux AIO,是Linux在内核实现的一套AIO接口。这套是"真・AIO"。接口的详细用法可以参考这里。...= IOCB_CMD_PWRITE; // 设置要“写入” cb.aio_buf = (uint64_t)data; // aio用的buffer cb.aio_offset = 0; // aio要写入的...反思AIO 上面讨论了这么多操作系统接口层面上的AIO,有很多细节和不完善的。但是,AIO在概念上却很简单,意思是通过一个回调处理数据。...这个模式可以清晰的反映出我们脑海中那个理想的AIO的样子。 但是现实是很悲催的,因为操作系统层面的AIO没法变成理想中的样子。 操作系统的AIO接口只支持文件操作。
Java 中的 BIO、NIO和 AIO 理解为是 Java 语言对操作系统的各种 IO 模型的封装。...在讲 BIO,NIO,AIO 之前先来回顾一下这样几个概念:同步与异步,阻塞与非阻塞。 同步与异步 同步: 同步就是发起一个调用后,被调用者未处理完请求之前,调用不返回。
以上的两组概念可以两两组合,就组合了我们熟悉的BIO、NIO、AIO。 3....异步非阻塞I/O(AIO): 异步非阻塞I/O,服务器实现模式为一个有效请求一个线程,客户端的IO请求都是由操作系统先完成了再通知服务器用其启动线程进行处理。...AIO方式适用于连接数目多且连接比较长(重操作)的架构,比如相册服务器,充分调用OS参与并发操作,编程比较复杂,jdk1.7开始支持。...AIO:我在厕所外做别的事,等有人来通知我了我再去占坑。
16.BIO、NIO、AIO 有什么区别? BIO:Block IO 同步阻塞式 IO,就是我们平常使用的传统 IO,它的特点是模式简单使用方便,并发处理能力低。...AIO:Asynchronous IO 是 NIO 的升级,也叫 NIO2,实现了异步非堵塞 IO ,异步 IO 的操作基于事件和回调机制。
所以本文也附带介绍了Linux 2.6及以后版本新增的AIO特性(因为这跟Java AIO是对应关系)。...Java AIO 1基本原理 目前为止,Java共支持3种网络编程模型:BIO、NIO、AIO: Java BIO : 同步并阻塞,服务器实现模式为一个连接一个线程,即客户端有连接请求时服务器端就需要启动一个线程进行处理...Linux AIO 1Linux AIO 简介 Linux 异步 I/O 是 Linux 内核中提供的一个相当新的增强。...3异步 I/O(AIO) 的动机 从前面 I/O 模型的分类中,我们可以看出 AIO 的动机。这种阻塞模型需要在 I/O 操作开始时阻塞应用程序。这意味着不可能同时重叠进行处理和 I/O 操作。...总结 使用异步 I/O(AIO)可以帮助我们构建 I/O 速度更快、效率更高的应用程序。
很多人说BIO不好,会“block”,但到底什么是IO的Block呢?考虑下面两种情况:
BIO, NIO, AIO,本身的描述都是在Java语言的基础上的。...而描述IO,我们需要从三个层面: 编程语言 实现原理 底层基础 从编程语言层面 BIO, NIO, AIO以Java的角度理解: BIO,同步阻塞式IO,简单理解:一个连接一个线程 NIO,同步非阻塞IO...而AIO,在windows上是通过IOCP实现的,在linux上还是通过epoll来实现的。...这里强调一点:AIO,这是I/O处理模式,而epoll等都是实现AIO的一种编程模型;换句话说,AIO是一种接口标准,各家操作系统可以实现也可以不实现。...Linux上还没有真正实现网络方式的AIO。
AIO(NIO.2):异步非阻塞式IO,服务器实现模式为一个有效请求一个线程,客户端的I/O请求都是由OS先完成了再通知服务器应用去启动线程进行处理。
---- IO 概述 IO 的操作方式通常分为几种:同步阻塞 BIO、同步非阻塞 NIO、异步非阻塞 AIO。 (1)在 JDK1.4 之前,我们建立网络连接的时候采用的是 BIO 模式。...(3)AIO 也就是 NIO 2,在 Java 7 中引入了 NIO 的改进版 NIO 2,它是异步非阻塞的IO 模型。...异步非阻塞 IO(AIO) (1)AIO 也就是 NIO 2,在 Java 7 中引入了 NIO 的改进版 NIO 2,它是异步非阻塞 的 IO 模型。...异步 IO 是基于事件和回调机制实现的,也就是说 AIO 模式不需要selector 操作,而是是事件驱动形式,也就是当客户端发送数据之后,会主动通知服 务器,接着服务器再进行读写操作。...(2)Java 的 AIO API 其实就是 Proactor 模式的应用,和 Reactor 模式类似。
异步非阻塞 AIO (NIO.2) 原理 服务器实现模式为一个有效请求一个线程,客户端的I/O请求都是由操作系统先完成了再通知服务器应用去启动线程进行处理。...AIO方式使用于连接数目多且连接比较长(重操作)的架构,比如相册服务器,充分调用操作系统参与并发操作,编程比较复杂,JDK7开始支持。...所以出现AIO。 如果你理解了Java NIO ,下面讲的netty也是水到渠成的事,只想说,深水区已过了! 差点忘记还要补下AIO的,这个比NIO先进的技术,最终实现了netty。...适用场景 适用于连接数比较多且连接比较长(重操作)的架构,比较相册服务器,充分调用OS参与并发操作,编程比较复杂,jdk7开始支持; 参考 BIO、NIO、AIO原理 Netty5 用户指南 BIO、NIO...、AIO适用场景
---- 下面分析下 阻塞I/O、NIO、AIO的数据处理流程 阻塞I/O 数据处理流程 ?...3.AIO 数据处理流程 ? AIO 实现原理 程序调用AIO的accept方法并传入Completionhandler,该方法是非阻塞方法。...程序只需要把具体的操作告知AIO就可以了,具体操作AIO来帮助你来操作。 NIO 和 AIO 性能上对比 AIO在性能上相对于NIO没有本质的提升。...AIO只是帮助你从内核中将数据复制到用户空间中,并调用你传入的回调方法。 NIO 是需要程序自己从内核中将数据复制到用户空间中,并需要程序自己调用相应的处理逻辑。 ----
2)Java AIO又称为NIO 2.0,难道它也是基于NIO来实现的? 3)Netty为什么会舍去了AIO的支持?(点此查看); 4)AIO看起来貌似只是解决了有无,实际是发布了个寂寞?...Java AIO的这些不合常理的现象难免会令人心存疑惑。所以决定写这篇文章时,我不想只是简单的把AIO的概念再复述一遍,而是要透过现象,深入分析、思考和并理解Java AIO的本质。...图片 8、Java AIO的本质是什么?...Netty之所以移除掉AIO:很大的原因是在性能上AIO并没有比NIO高。...Linux虽然也有一套原生的AIO实现(类似Windows上的IOCP),但Java AIO在Linux并没有采用,而是用epoll来实现。 Java AIO不支持UDP。
IO通常分为几种,BIO(阻塞 Blocking IO)、NIO(非阻塞 Non-Blocking IO)、AIO(异步非阻塞)。...AIO AIO没有前两者普及,暂不讨论!
项目地址:https://github.com/windwant/windwant-demo/tree/master/io-service Server: package org.windwant.io.aio...IOException { new Thread(new AIOServer(8989, 19)).start(); } } Client: package org.windwant.aio...} }); } } 2017-12-11 改造client: AsynchronousChannelGroup package org.windwant.io.aio
周末午后,在家里面进行电话面试,我问了面试者几个关于IO的问题,其中包括什么是BIO、NIO和AIO?三者有什么区别?具体如何使用等问题,但是面试者回答的并不是很满意。...分别是BIO、NIO和AIO。 Java BIO BIO 全称Block-IO 是一种同步且阻塞的通信模式。是一个比较传统的通信方式,模式简单,使用方便。但并发处理能力低,通信耗时,依赖网速。...Java AIO Java AIO,全程 Asynchronous IO,是异步非阻塞的IO。是一种非阻塞异步的通信模式。...AIO (Asynchronous I/O):异步非阻塞I/O模型。 那么,同步阻塞、同步非阻塞、异步非阻塞都是怎么回事呢?...AIO方式适用于连接数目多且连接比较长(重操作)的架构,比如相册服务器,充分调用OS参与并发操作,编程比较复杂,JDK7开始支持。 使用方式 使用BIO实现文件的读取和写入。
IO 调用接口 函数 功能 原型 aio_read 请求异步读操作 int aio_read(struct aiocb *aiocbp); aio_write 请求异步写操作 int aio_write...(struct aiocb *aiocbp); aio_error 检查异步请求的状态 int aio_error(const struct aiocb *aiocbp); aio_return 获得完成的异步请求的返回状态...ssize_t aio_return(struct aiocb *aiocbp); aio_suspend 挂起调用进程,直到一个或多个异步请求已经完成(或失败) int aio_suspend(const...函数说明 4.1. aio_read、aio_write int aio_read( struct aiocb *aiocbp ); int aio_write( struct aiocb *aiocbp...成功取消返回 AIO_CANCELED,请求已经完成则返回 AIO_NOTCANCELED。
本文内容涉及同步与异步, 阻塞与非阻塞, BIO、NIO、AIO等概念, 这块内容本身比较复杂, 很难用三言两语说明白. 而书上的定义更不容易理解是什么意思. 下面跟着我一起解开它们神秘的面纱。...BIO 传统的socket编程,属于同步阻塞模型 NIO 官方(new io) jdk1.4推出 俗称(non-block io) ,属于同步非阻塞模式 AIO 又称NIO2.0在jdk1.7推出...3、AIO编程 NIO 2.0引入了新的异步通道的概念,并提供了异步文件通道和异步套接字通道的实现。 异步的套接字通道时真正的异步非阻塞I/O,对应于UNIX网络编程中的事件驱动I/O(AIO)。
Netty序章之BIO NIO AIO演变 Netty是一个提供异步事件驱动的网络应用框架,用以快速开发高性能、高可靠的网络服务器和客户端程序。...Netty并非横空出世,它是在BIO,NIO,AIO演变中的产物,是一种NIO框架。而BIO,NIO,AIO更是笔试中要考,面试中要问的技术。也是一个很好的加分项,加分就是加工资,你还在等什么?...AIO 也叫NIO2.0 是一种非阻塞异步的通信模式。...AIO服务端代码,负责创建服务器通道,绑定端口,等待请求。...AIO 非阻塞异步通信模式,NIO的升级版,采用异步通道实现异步通信,其read和write方法均是异步方法。
领取专属 10元无门槛券
手把手带您无忧上云