高并发环境下,我知道优化配置tomcat,对连接数和线程池作修改,最重要的是connector的协议Http Connector使用NIO,而不是默认的AJP Connector,当时也没有仔细研究其原理。现在来为以上这些设置做一下剖析。
要了解这些,不能避开tomcat最重要的一个功能,就是connector连接器。
它的作用可是tomcat的核心,在tomcat的配置文件server.xml中写到过:Connector的主要功能是接收连接请求,创建request和response对象用于和请求端交换数据;然后分配线程给engine(servlet容器)来处理请求,并把request和response对象传递给engine引擎,当engine处理完请求后,也会通过Connector将响应返回给客户端。
现在终于知道其原理了,而且也知道了request和response二大对象是由谁创建的。
可以说servlet容器处理请求,是需要Connector连接器进行调度和控制的,Connector连接器是tomcat处理请求的主干,因此对Connector的配置和使用,对tomcat的性能有着决定性的作用,我们就聊一聊Connector连接器的配置选项,连接协议,连接数,线程池 。
先谈谈连接协议,tomcat的连接协议主要有二种:HTTP Connector 和 AJP Connector(默认),我们主要讨论HTTP Connector
一、BIO、NIO、APR
1、Connector的protocol
Connector在处理HTTP请求时,会使用不同的protocol。不同的Tomcat版本支持的protocol不同,其中最典型的protocol包括BIO、NIO和APR(Tomcat7中支持这3种,Tomcat8增加了对NIO2的支持,而到了Tomcat8.5和Tomcat9.0,则去掉了对BIO的支持)。
BIO是Blocking IO,顾名思义是阻塞的IO;NIO是Non-blocking IO,则是非阻塞的IO。而APR是Apache Portable Runtime,是Apache可移植运行库,利用本地库可以实现高可扩展性、高性能;Apr是在Tomcat上运行高并发应用的首选模式,但是需要安装apr、apr-utils、tomcat-native等包。(之前没有用过APR,看来高并发下要使用此协议啊)
2、如何指定protocol
Connector使用哪种protocol,可以通过<connector>元素中的protocol属性进行指定,也可以使用默认值。
指定的protocol取值及对应的协议如下:
-
HTTP/1.1:默认值,使用的协议与Tomcat版本有关
-
org.apache.coyote.http11.Http11Protocol:BIO
-
org.apache.coyote.http11.Http11NioProtocol:NIO
-
org.apache.coyote.http11.Http11Nio2Protocol:NIO2
-
org.apache.coyote.http11.Http11AprProtocol:APR
如果没有指定protocol,则使用默认值HTTP/1.1,其含义如下:在Tomcat7中,自动选