首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Linux 原生 AIO 实现(Native AIO

上一篇文章 主要分析了 Linux 原生 AIO 的原理和使用,而这篇要介绍的是 Linux 原生 AIO实现过程。...本文基于 Linux-2.6.0 版本内核源码 一般来说,使用 Linux 原生 AIO 需要 3 个步骤: 1) 调用 io_setup 函数创建一个一般 IO 上下文。...所以,我们可以通过分析这三个函数的实现来理解 Linux 原生 AIO实现Linux 原生 AIO 实现在源码文件 /fs/aio.c 中。...总结 本文主要分析了 Linux 原生 AIO实现,但为了不陷入太多的实现细节中,本文并没有涉及到磁盘 IO 相关的知识点。...然而磁盘 IO 也是 AIO 实现中不可或缺的一部分,所以有兴趣的朋友可以继续通过阅读 Linux 的源码来分析其实现原理。

2.5K20

linux AIO -- libaio 实现的异步 IO 简介及实现原理

1. linux AIO — libaio 实现的异步 IO POSIX AIO 是在用户控件模拟异步 IO 的功能,不需要内核支持,而 linux AIO 则是 linux 内核原声支持的异步 IO...关于 linux IO 模型及 AIO、POSIX AIO 的简介,请参看上一篇文章 libaio 实现的异步 IO 主要包含以下接口: libaio 实现的异步 IO 函数 功能 原型 io_setup...与 POSIX AIO 区别 从上图中的流程就可以看出,linux 版本的 AIO 与 POSIX 版本的 AIO 最大的不同在于 linux 版本的 AIO 实际上利用了 CPU 和 IO 设备异步工作的特性...而 POSIX AIO 利用了线程与线程之间的异步工作特性,在用户线程中实现 IO 的异步操作。...POSIX AIO 支持非 direct-io,而且实现非常灵活,可配置性很高,可以利用内核提供的page cache来提高效率,而 linux 内核实现AIO 就只支持 direct-io,cache

2.5K30
您找到你想要的搜索结果了吗?
是的
没有找到

Java新一代网络编程模型AIO原理及Linux系统AIO介绍

所以本文也附带介绍了Linux 2.6及以后版本新增的AIO特性(因为这跟Java AIO是对应关系)。...Java AIO 1基本原理 目前为止,Java共支持3种网络编程模型:BIO、NIO、AIO: Java BIO : 同步并阻塞,服务器实现模式为一个连接一个线程,即客户端有连接请求时服务器端就需要启动一个线程进行处理...2AIO介绍 jdk在1.4版本的nio中提供了对非阻塞多路复用同步io模型的支持,但是在Windows上是基于较低效select/poll实现的。...Linux AIO 1Linux AIO 简介 Linux 异步 I/O 是 Linux 内核中提供的一个相当新的增强。...2Linux 的 I/O 模型 在深入介绍 AIO API 之前,让我们先来探索一下 Linux 上可以使用的不同 I/O 模型。

1.7K80

聊聊BIO,NIO和AIO (2)磁盘IO磁盘IO的优化AIO反思AIO

所以比如你用POSIX AIO实现了一个lib,选用数字M做信号;但是你无法阻止其他人用POSIX AIO实现另外一个lib,也选用数字M做信号。这样如果一个程序同时用了两套lib,就会彼此干扰。...Linux下实际使用比较多的是Linux AIOLinux AIO Linux中的另外一套AIO接口被称为Linux AIO,是Linux在内核实现的一套AIO接口。这套是"真・AIO"。...这套接口在Linux内核中实现,看上去靠谱多了。但是这套接口有三个比较令人郁闷的问题。 第一个问题是,它只支持Direct IO的IO操作。...Linux提供了eventfd解决这个问题。 使用eventfd协调epoll和Linux AIO 如果在Linux下编写一个高性能文件服务器,就需要同时用到epoll和Linux AIO。...所以现实当中,用不用是要做取舍的(nginx有一个选项aio就是配置这个功能的,见这里)。 Linux AIO不能100%实现所有文件操作api都能“异步”。

3.9K90

Linux 原生异步 IO 原理与使用(Native AIO

Linux 原生 AIO 原理 Linux Native AIOLinux 支持的原生 AIO,为什么要加原生这个词呢?...本文主要介绍 Linux 原生 AIO 的原理和使用,所以不会对其他第三方的异步 IO 库进行分析,下面我们先来介绍 Linux 原生 AIO 的原理。 如 图2 所示: ?...下面我们主要分析,Linux 内核是怎么实现异步 IO 的。...Linux 原生 AIO 使用 在介绍 Linux 原生 AIO实现之前,先通过一个简单的例子来介绍其使用过程: #define _GNU_SOURCE #include #...总结 本文主要介绍了 Linux 原生 AIO 的原理和使用,Linux 原生 AIO 的使用比较简单,但其内部实现比较复杂,在下篇文章中将会介绍 Linux 原生 AIO实现

3.2K10

BIO、NIO、AIO

以上的两组概念可以两两组合,就组合了我们熟悉的BIO、NIO、AIO。 3....同步非阻塞I/O(NIO): 同步非阻塞I/O,服务器实现模式为一个请求一个线程,即客户端发送的连接请求都会注册到多路复用器上,多路复用器轮询到连接有IO请求时才启动一个线程进行处理。...异步非阻塞I/O(AIO): 异步非阻塞I/O,服务器实现模式为一个有效请求一个线程,客户端的IO请求都是由操作系统先完成了再通知服务器用其启动线程进行处理。...AIO方式适用于连接数目多且连接比较长(重操作)的架构,比如相册服务器,充分调用OS参与并发操作,编程比较复杂,jdk1.7开始支持。...AIO:我在厕所外做别的事,等有人来通知我了我再去占坑。

67975

BIO,NIO,AIO总结

Java 中的 BIO、NIO和 AIO 理解为是 Java 语言对操作系统的各种 IO 模型的封装。...在讲 BIO,NIO,AIO 之前先来回顾一下这样几个概念:同步与异步,阻塞与非阻塞。 同步与异步 同步: 同步就是发起一个调用后,被调用者未处理完请求之前,调用不返回。...尤其在 Linux 这样的操作系统中,线程本质上就是一个进程,创建和销毁线程都是重量级的系统函数。...采用线程池和任务队列可以实现一种叫做伪异步的 I/O 通信框架,它的模型图如上图所示。...伪异步I/O通信框架采用了线程池实现,因此避免了为每个请求都创建一个独立线程造成的线程资源耗尽问题。不过因为它的底层仍然是同步阻塞的BIO模型,因此无法从根本上解决问题。

87110

聊聊BIO,NIO和AIO (1)

Linux认为: 对于第一种情况,算作block,因为Linux无法知道网络上对方是否会发数据。如果没数据发过来,对于调用read的程序来说,就只能“等”。...于是,网络服务为了同时响应多个并发的网络请求,必须实现为多线程的。每个线程处理一个网络请求。线程数随着并发连接数线性增长。这的确能奏效。实际上2000年之前很多网络服务器就是这么实现的。...Java NIO,nginx等在对应的平台的上都是使用这些api实现。 因为大部分情况下我会用Linux做服务器,所以下文以Linux epoll为例子来解释多路复用是怎么工作的。...用epoll实现的IO多路复用 epoll是Linux下的IO多路复用的实现。这里单开一章是因为它非常有代表性,并且Linux也是目前最广泛被作为服务器的操作系统。...在Linux下,基于epoll的IO多路复用是解决这个问题的最佳方案;epoll相比select和poll有很大的性能优势和功能优势,适合实现高性能网络服务。

74630

聊聊BIO,NIO和AIO (2)

所以比如你用POSIX AIO实现了一个lib,选用数字M做信号;但是你无法阻止其他人用POSIX AIO实现另外一个lib,也选用数字M做信号。这样如果一个程序同时用了两套lib,就会彼此干扰。...Linux下实际使用比较多的是Linux AIOLinux AIO Linux中的另外一套AIO接口被称为Linux AIO,是Linux在内核实现的一套AIO接口。这套是"真・AIO"。...这套接口在Linux内核中实现,看上去靠谱多了。但是这套接口有三个比较令人郁闷的问题。 第一个问题是,它只支持Direct IO的IO操作。...Linux提供了eventfd解决这个问题。 使用eventfd协调epoll和Linux AIO 如果在Linux下编写一个高性能文件服务器,就需要同时用到epoll和Linux AIO。...所以现实当中,用不用是要做取舍的(nginx有一个选项aio就是配置这个功能的,见这里)。 Linux AIO不能100%实现所有文件操作api都能“异步”。

1.3K20

简单谈谈BIO,NIO,AIO

---- 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 模式类似。

19050

到底什么是Java AIO?为什么Netty会移除AOI?一文搞懂AIO的本质!

只运行AIO服务端程序,客户端不运行,打印一下线程栈(备注:程序在Linux平台上运行,其他平台略有差异)。如下图所示。...提到epoll,我们印象中,Java NIO在Linux平台底层就是用epoll来实现的,难道Java AIO也是用epoll来实现么? 为了证实这个结论,我们从下一个问题来展开讨论。...8.1Java AIO的本质,就是只在用户态实现了异步 由于内核态无法直接调用用户态函数,Java AIO的本质,就是只在用户态实现异步,并没有达到理想意义上的异步。...8.2Java AIO的其它真相 Java AIO跟NIO一样:在各个平台的底层实现方式也不同,在Linux是用epoll、Windows是IOCP、Mac OS是KQueue。...Linux虽然也有一套原生的AIO实现(类似Windows上的IOCP),但Java AIOLinux并没有采用,而是用epoll来实现。 Java AIO不支持UDP。

23120

宋宝华: 数据库为什么有可能喜欢Linux AIO(异步IO)?

回忆一下 我们都知道Linux的IO模型有阻塞、非阻塞、SIGIO、多路复用(select,epoll)、AIO(异步I/O)等。 数据库可能比较倾向于使用AIO。...但是其底层其实也是靠epoll()来实现,这个我们透过strace就可以看出。...而AIO则是不管三七二十一,直接发IO请求,但是并不等待这个请求的结束,让Linux后台自己去完成读写。我们来看一个典型的AIO编程案例: ?...AIO和传统epoll()的本质区别是,epoll()等方式,它只是一个事件获取机制,获取事件后,之后的read(), write()还是要走Linux的传统路线,经过Linux内核本身的各个层次(如page...Linux native的AIO本身call的函数,本身就是系统调用。strace执行AIO动作的进程得到的直接就是类似如下的结果: strace .

1.8K20
领券