BIO、NIO、AIO分别是什么?
BIO(Blocking IO)同步阻塞式IO
BIO是传统的同步阻塞IO,即客户端发起请求,服务器必须开一个线程接收请求,并开启一个线程进行处理,直到处理完毕后再通过一个线程返回结果。在高并发的情况下,服务器线程开销巨大,容易导致线程堆积和资源浪费。
NIO(Non-blocking IO) 同步非阻塞IO
NIO是一种同步非阻塞IO模型,它通过Selector轮询操作,将阻塞转化为非阻塞。当有数据可读写时,才会去执行相应的IO操作,从而减少了线程的开销和资源的浪费。
AIO(Asynchronous IO)异步非阻塞IO
AIO是一种异步非阻塞IO模型,在AIO模型中,当发起一个IO操作后,线程不会等待,而是继续执行其他操作,当IO操作完成后,该线程会收到通知,从而可以回来处理IO操作的结果。AIO相比NIO的优点是在网络连接处于空闲状态时,不需要通过Selector轮询操作,减少了时间和资源的浪费。
为什么要用Jetty来替换Tomcat?
Tomcat9.0版本之前默认是BIO模式,Tomcat9.0版本才改成默认NIO模式。如果要把Tomcat9.0之前的BIO模式改为NIO模式会非常麻烦。Jetty默认就是NIO模式,性能方面与Tomcat不相上下。另外Google大量的web服务器是发布到Jetty服务器上的,因此可以放心大胆的使用Jetty。
如何在springboot中如何使用Jetty替换Tomcat?
1、在springboot中剔除Tomcat
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
<exclusions>
<exclusion>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-tomcat</artifactId>
</exclusion>
</exclusions>
</dependency>
2、添加Jetty依赖
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-jetty</artifactId>
</dependency>
3、添加Jetty服务器配置
server:
jetty:
threads:
acceptors: 4 # acceptors线程池用于接受HTTP请求
selectors: 8 # selectors线程池用于处理HTTP请求
min: 8
max: 200