aio-enhance v1.0.5 发布,Java AIO 内核增强类库

栏目: 软件资讯 · 发布时间: 3年前

内容简介:aio_enhance 是一款无侵入式的 Java AIO 内核增强类库(注意:这不是一款通信框架),解决 Oracle 官方 Java AIO 的设计缺陷,提供更高效、更稳定的通信能力。 aio_enhance 采用了 NIO 技术,再结合自研的异步线程...

aio_enhance 是一款无侵入式的 Java AIO 内核增强类库注意:这不是一款通信框架),解决 Oracle 官方 Java AIO 的设计缺陷,提供更高效、更稳定的通信能力。

aio_enhance 采用了 NIO 技术,再结合自研的异步线程模型重写了 AIO 实现逻辑,100% 兼容官方定义的接口。用户可自由选择 Oracle 官方提供的,或者 aio_enhance 增强的 AIO 实现,架构如下图。

aio-enhance v1.0.5 发布,Java AIO 内核增强类库

除了线程模型的设计,我们还对 IO 调度模型做了一些改进。经由 aio_enhance 增强的通信服务,相较于官方 Java AIO 的吞吐能力会有 100% ~ 400% 的提升幅度。而相较业界主流 NIO 框架,aio_enhance 的性能表现高出 50% 以上。

一、项目背景

1.1 解决平台兼容性问题。

Java 原生 AIO 在 Mac 操作系统下存在兼容性问题,进行性能压测会偶发性的系统崩溃。

1.2 修复官方 AIO 架构缺陷

Java 原生 AIO 在底层架构设计上存在缺陷(参考:Java AIO通信模型)。多核 CPU 环境下处理高并发请求,会引发比较严重的锁竞争现象,以致无法充分发挥机器性能。

普通4核机器竞争压力不大,AIO 的运行表现实测优于NIO。但随着 CPU 核数的增加,AIO 的性能优势逐渐下降。

1.3 优化 AIO 线程模型

Java AIO 相较于 NIO 多了一层异步线程模型,极大降低了开发人员的编程难度。但是通信过程中的 accept、connect、read、write 等事件都是复用同一组线程资源,容易造成读写回调进入死锁状态。 AIO通信框架在设计上需要特别关注这一点,但如果引入 aio-enhance 则无此顾虑。

二、适用场景

如果您符合以下几个条件,aio-enhance 会是一个不错的选择。

  • 基于 Java AIO 实现的通信框架,并且想要获得卓越的性能表现。如:smart-socket;
  • 对高并发、低延迟有严苛要求;

三、更新内容

  1. bugfix:修复同步 IO 模式下可能引发的线程死锁问题。(感谢网友 @想你所想 反馈)
  2. 优化:优化 IO 调度,性能提升约 7%。

四、集成

步骤一:依赖

引入增强包:aio-enhance.jar。可以通过maven方式引入依赖,亦可直接下载 jar 包并导入classpath。

<dependency>
	<groupId>org.smartboot.aio</groupId>
	<artifactId>aio-enhance</artifactId>
	<version>1.0.5</version>
</dependency>

步骤二:启动

可以通过硬编码的方式设置系统属性,如下:

System.setProperty("java.nio.channels.spi.AsynchronousChannelProvider", "org.smartboot.aio.EnhanceAsynchronousChannelProvider");

也可在 java 启动命令行中设置,如下:

java -Djava.nio.channels.spi.AsynchronousChannelProvider=org.smartboot.aio.EnhanceAsynchronousChann

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

算法设计、分析与实现

算法设计、分析与实现

徐子珊 / 2012-10 / 65.00元

《算法设计、分析与实现:c、c++和java》由徐子珊编著,第1章~第6章按算法设计技巧分成渐增型算法、分治算法、动态规划算法、贪婪算法、回溯算法和图的搜索算法。每章针对一些经典问题给出解决问题的算法,并分析算法的时间复杂度。这样对于初学者来说,按照算法的设计方法划分,算法思想的阐述比较集中,有利于快速入门理解算法的精髓所在。一旦具备了算法设计的基本方法,按应用领域划分专题深入学习,读者可以结合已......一起来看看 《算法设计、分析与实现》 这本书的介绍吧!

在线进制转换器
在线进制转换器

各进制数互转换器

RGB CMYK 转换工具
RGB CMYK 转换工具

RGB CMYK 互转工具

HEX CMYK 转换工具
HEX CMYK 转换工具

HEX CMYK 互转工具