Tomcat Connector三种运行模式(BIO, NIO, APR)的比较和优化
这三种模式的不同之处如下:
- BIO:
一个线程处理一个请求。缺点:并发量高时,线程数较多,浪费资源。
Tomcat7或以下,在Linux系统中默认使用这种方式。
- NIO:
利用Java的异步IO处理,可以通过少量的线程处理大量的请求。
Tomcat8在Linux系统中默认使用这种方式。
Tomcat7必须修改Connector配置来启动:
<Connector port="8080" protocol="org.apache.coyote.http11.Http11NioProtocol"
connectionTimeout="20000" redirectPort="8443"/>
- APR:
即Apache Portable Runtime,从操作系统层面解决io阻塞问题。
Tomcat7或Tomcat8在Win7或以上的系统中启动默认使用这种方式。
Linux如果安装了apr和native,Tomcat直接启动就支持apr。(安装方法:http://www.cnblogs.com/nb-blog/p/5278502.html)
Tomcat启动的时候,可以通过log看到Connector使用的是哪一种运行模式:
- Starting ProtocolHandler ["http-bio-8080"]
- Starting ProtocolHandler ["http-nio-8080"]
- Starting ProtocolHandler ["http-apr-8080"]
安装配置apr
1、安装expat库,yum install expat-devel
2、安装apr-1.5.2.tar.gz和apr-util-1.5.4.tar.gz
解压apr-1.5.2.tar.gz和apr-util-1.5.4.tar.gz
tar -zxvf apr-1.5.2.tar.gz
tar -zxvf apr-util-1.5.4.tar.gz
检测、编译、安装
进入到apr-1.5.2,执行
./configure --prefix=/usr/local/apr && make && make install
进入到apr-util-1.5.4,执行
./configure --with-apr=/usr/local/apr/ --prefix=/usr/local/apr-utils && make && make install
3、安装Tomcat-native
该包在tomcat下的bin下有压缩包
解压安装。
./configure --with-apr=/jk/app/apr/bin/apr-1-config --with-java-home=/jk/app/jdk1.8.0_201 -prefix=/jk/app/tomcat-native && make && make install
4、修改tomcat配置文件,增加文件目录
# apr lizq8/20190404
JAVA_OPTS="$JAVA_OPTS -Djava.library.path=/jk/app/apr/lib"
JAVA_OPTS="$JAVA_OPTS -Djava.library.path=/jk/app/tomcat-native/lib"
5、修改server配置
<Connector port="80" protocol="org.apache.coyote.http11.Http11AprProtocol"
connectionTimeout="20000"
redirectPort="8443" />
6、修正系统最大可以打开的文件数(root可修改为其他用户)
在vi /etc/security/limits.conf中添加如下设置:
# max open files config for elasticsearch
root soft nofile 65535
root hard nofile 65535
配置BIO
<Connector port="8080" protocol="HTTP/1.1" connectionTimeout="20000" redirectPort="8443" />
配置NIO
<Connector port="8080" protocol="org.apache.coyote.http11.Http11NioProtocol"
connectionTimeout="20000"
redirectPort="8443" />