BIO、AIO、NIO

BIO


Blocking IO:同步阻塞,一个线程一个连接,一个请求就需要一个线程。如果连接不做读写,那么线程就会闲置。线程的开销大。

优点及应用场景:适用于连接数目小且固定的架构。对服务器的资源要求较高,并发局限与应用中。但简单易于理解。

NIO


Non-Blocking IO:同步非阻塞,一个请求一个线程,但连接请求都是先注册到多路复用器上,多路复用器轮询到连接有IO请求时才启动一个线程处理。

在这里插入图片描述
优点及应用场景:适用于连接数目多且连接时间短的架构,如聊天服务器、弹幕系统、分布式系统通信。

三大核心组件:selector、channel、buffer

线程通过selector 来处理多个通道
面向缓冲区编程,channel和client不直接操作,而是通过缓冲区来进行操作。

AIO

Asynchronous I/O:异步非阻塞,一个有效请求一个线程,客户端的IO请求都由OS先完成了再通知服务器去启动线程处理。

优点及应用场景:适用于连接数目比较多且长的架构,如相册服务器。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章