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