BIO
Blocking IO:同步阻塞,一个线程一个连接,一个请求就需要一个线程。如果连接不做读写,那么线程就会闲置。线程的开销大。
优点及应用场景:适用于连接数目小且固定的架构。对服务器的资源要求较高,并发局限与应用中。但简单易于理解。
NIO
Non-Blocking IO:同步非阻塞,一个请求一个线程,但连接请求都是先注册到多路复用器上,多路复用器轮询到连接有IO请求时才启动一个线程处理。
优点及应用场景:适用于连接数目多且连接时间短的架构,如聊天服务器、弹幕系统、分布式系统通信。
三大核心组件:selector、channel、buffer
线程通过selector 来处理多个通道
面向缓冲区编程,channel和client不直接操作,而是通过缓冲区来进行操作。
AIO
Asynchronous I/O:异步非阻塞,一个有效请求一个线程,客户端的IO请求都由OS先完成了再通知服务器去启动线程处理。
优点及应用场景:适用于连接数目比较多且长的架构,如相册服务器。