Netty学习(一)——BIO/伪异步IO/NIO/AIO四种IO模型的演变
创始人
2024-02-08 15:04:56

IO模型历经了从BIO到伪异步IO,到NIO,再到AIO这四种IO模型的演变。其中伪异步IO是非官方说法。

一、BIO

BIO即Block Input Output,同步阻塞IO
BIO通信模型的服务端,通常由一个独立的Acceptor线程负责监听客户端的连接,它接收到客户端连接请求后,为每个客户端创建一个新的线程进行链路处理,处理完成之后,通过输出流返回应答给客户端,线程销毁。
该模型最大的问题就是缺乏弹性伸缩能力,当客户端并发访问量增加后,服务端的线程个数和客户端并发访问数呈1:1的正比关系。因为线程是JVM非常宝贵的系统资源,当线程数膨胀之后,系统的性能将急剧下降,随着并发访问量的继续增大,系统会发生线程堆栈溢出、创建新线程失败等问题,并最终导致进程宕机或僵死,不能对外提供服务。因此很显然,这种模型无法满足高性能、高并发接入的场景。

二、伪异步IO

为了改进一线程一连接的这种模型,演进出了一种通过线程池或消息队列实现一个或多个线程处理N个客户端的模型。由于这种模型的底层通信机制依然使用同步阻塞IO,所以被称为“伪异步”。该模型服务端的线程池最大线程数N,与客户端个数M,形成N:M的比例关系,其中M可以远远大于N。通过线程池可以灵活地调配线程资源,设置线程的最大值,防止由于海量并发接入而导致线程耗尽。
伪异步IO实际上仅仅是对BIO线程模型的一个简单优化,无法从根本上解决同步IO导致的通信线程阻塞问题。

三、NIO

官方将NIO称之为 New I/O,因为它相对于之前的I/O类库是新增的。
但是更多的人喜欢称之为Non-block I/O,非阻塞IO,因为非阻塞I/O更能体现NIO的特点。

【NIO三大组件】

  1. 缓冲区 Buffer:在NIO库中,所有数据都是用缓冲区处理的。读数据时,直接读到缓冲区中;写数据时,写入到缓冲区中。
  2. 通道 Channel:通道与流的不同之处在于通道是双向的,流只是在一个方向上移动,而通道可以用于读、写或者二者同时进行。即Channel是全双工的。
  3. 多路复用选择器 Selector:多路复用选择器是NIO实现非阻塞I/O的关键。多路复用的核心就是Selector不断轮询注册在其上的Channel,如果某个Channel上面发生读或写事件,这个Channel就处于就绪状态,会被Selector轮询出来,然后通过SelectionKey可以获取就绪Channel的集合,进行后续的I/O操作。

由于JDK的Selector在Linux等主流操作系统上通过epoll实现,它没有连接句柄数的限制,这意味着一个Selector线程可以同时处理成千上万个客户端连接,而且性能不会随着客户端的增加而线性下降。因此,该模型非常适合做高性能、高负载的网络服务器。

四、AIO

AIO即Asynchronous Input Output,异步IO
JDK7升级了NIO类库,升级后的NIO类库被称为NIO2.0,NIO2.0的异步套接字通道是真正的异步非阻塞I/O,对应于UNIX网络编程中的事件驱动I/O,即AIO。该模型不需要通过多路复用选择器Selector对注册的通道进行轮询操作即可实现异步读写,从而简化了NIO的编程模型。

相关内容

热门资讯

健康中国建设,如何提质增效再出... 澎湃新闻记者 张依琳《中华人民共和国国民经济和社会发展第十五个五年规划纲要(草案)》(以下简称“十五...
消保3.15丨三国篇 “借力... (来源:中海信托)
西藏开投安多100MW光热部分... (来源:CSPPLAZA光热发电平台)3月6日,中国电建集团西北勘测设计研究院有限公司就西藏开投安多...
新希望:商品猪销售收入13.2... 格隆汇3月6日|新希望公告,司2026年2月销售商品猪98.22万头,环比变动-12.44%,同比变...
卫光生物:收到药品注册临床试验... 格隆汇3月6日|卫光生物公告,近日收到国家药品监督管理局签发的人凝血因子Ⅸ境内生产药品注册临床试验申...