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

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的编程模型。

相关内容

热门资讯

中证A500ETF摩根(560... 8月22日,截止午间收盘,中证A500ETF摩根(560530)涨1.19%,报1.106元,成交额...
A500ETF易方达(1593... 8月22日,截止午间收盘,A500ETF易方达(159361)涨1.28%,报1.104元,成交额1...
何小鹏斥资约2.5亿港元增持小... 每经记者|孙磊    每经编辑|裴健如 8月21日晚间,小鹏汽车发布公告称,公司联...
中证500ETF基金(1593... 8月22日,截止午间收盘,中证500ETF基金(159337)涨0.94%,报1.509元,成交额2...
中证A500ETF华安(159... 8月22日,截止午间收盘,中证A500ETF华安(159359)涨1.15%,报1.139元,成交额...
科创AIETF(588790)... 8月22日,截止午间收盘,科创AIETF(588790)涨4.83%,报0.760元,成交额6.98...
创业板50ETF嘉实(1593... 8月22日,截止午间收盘,创业板50ETF嘉实(159373)涨2.61%,报1.296元,成交额1...
港股异动丨航空股大幅走低 中国... 港股航空股大幅下跌,其中,中国国航跌近7%表现最弱,中国东方航空跌近5%,中国南方航空跌超3%,美兰...
电网设备ETF(159326)... 8月22日,截止午间收盘,电网设备ETF(159326)跌0.25%,报1.198元,成交额409....
红利ETF国企(530880)... 8月22日,截止午间收盘,红利ETF国企(530880)跌0.67%,报1.034元,成交额29.0...