本次讨论Tomcat三种接收请求的方式,其中主要对APR的安装进行详细描述。
bio(blocking I/O),顾名思义,即阻塞式I/O操作,表示Tomcat使用的是传统的Java I/O操作(即java.io包及其子包)。Tomcat在默认情况下,就是以bio模式运行的。遗憾的是,就一般而言,bio模式是三种运行模式中性能最低的一种。我们可以通过Tomcat Manager来查看服务器的当前状态。现在互联网公司很少有人使用这种模式了
是Java SE 1.4及后续版本提供的一种新的I/O操作方式(即java.nio包及其子包)。Java nio是一个基于缓冲区、并能提供非阻塞I/O操作的Java API,因此nio也被看成是non-blocking I/O的缩写。它拥有比传统I/O操作(bio)更好的并发运行性能。在Tomcat8.0后开始默认使用NIO。
(Apache Portable Runtime/Apache可移植运行库),是Apache HTTP服务器的支持库。你可以简单地理解为,Tomcat将以JNI的形式调用Apache HTTP服务器的核心动态链接库来处理文件读取或网络传输操作,从而大大地提高Tomcat对静态文件的处理性能。 Tomcat apr也是在Tomcat上运行高并发应用的首选模式。
server.xml 配置
<Connector port="8080" protocol="HTTP/1.1"
connectionTimeout="20000"
redirectPort="8443" />
server.xml 配置
<Connector port="8080" protocol="org.apache.coyote.http11.Http11NioProtocol"
connectionTimeout="20000"
redirectPort="8443" />
server.xml 配置
<Connector port="8080" protocol="org.apache.coyote.http11.Http11AprProtocol"
connectionTimeout="20000"
redirectPort="8443" />
安装 apr时,需要同时安装apr 、 apr-utils 、tomcat-native包
下载地址:http://apr.apache.org/download.cgi
下载完成之后进行安装
apr 安装
tar zxf apr-1.7.0.tar.gz -C /usr/local/src/
cd /usr/local/src/apr-1.7.0/
./configure --prefix=/usr/local/apr
make && make install
apr-iconv-1.2.2安装
tar zxf apr-iconv-1.2.2.tar.gz -C /usr/local/src/
cd /usr/local/src/apr-iconv-1.2.2/
./configure -prefix=/usr/local/apr-iconv --with-apr=/usr/local/apr
make && make install
apr-utils 安装
tar zxf apr-util-1.6.1.tar.gz -C /usr/local/src/
cd /usr/local/src/apr-util-1.6.1/
./configure -prefix=/usr/local/apr-util --with-apr=/usr/local/apr --with-apriconv=/usr/local/apr-iconv
make && make install
tomcat-native安装
cd /usr/local/apache-tomcat-7.0.65/bin/
tar zxf tomcat-native.tar.gz
cd tomcat-native-1.2.22-src/jni/native
./configure --with-apr=/usr/local/apr --with-java-home=/Library/Java/JavaVirtualMachines/jdk1.8.0_191.jdk/Contents/Home --with-ssl=/usr/local/Cellar/openssl/1.0.2s
make && make install
如果中间没有报错,安装完后记得在修改环境变量,在JAVA变量后面多加一条APR的环境变量如下:
JAVA_HOME=/usr/local/java
JAVA_BIN=$JAVA_HOME/bin
PATH=$PATH:$JAVA_BIN
CLASSPATH=$JAVA_HOME/lib/dt.jar:$JAVA_HOME/lib/tools.jar
export JAVA_HOME JAVA_BIN PATH CLASSPATH
export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:/usr/local/apr/lib
执行如下命令,生效环境变量
source .bash_profile
更新gcc,安装openssl,安装expat和expat-devel
brew install gcc
brew install openssl
brew install expat
brew install expat-devel
给openssl创建快捷链接
ln -s /usr/local/Cellar/openssl/1.0.2s/bin/openssl /usr/bin/openssl
ln -s /usr/local/Cellar/openssl/1.0.2s/include/openssl /usr/include/openssl
这个问题在不同操作系统下的解决方案
在window下启动的时候会提示was not found on the java.library.path
: 这个根据每个人的环境不同,可能给出的路径也不太一样,只要把Native library拷贝到上述路径之一即可,Native library是什么呢,网上有提供下载,其实不要那么麻烦,在tomcat的bin目录下就有,文件名是:tcnative-1.dll
(注意版本问题)。例如我把这个文件拷贝到$JAVA_HOME\bin
下,然后再启动tomcat就没有上述的提示了,这个网上好多教程。
linux下比较复杂一点,因为tomcat包中没有提供编译好的so文件,所以需要自己编译,tomcat发行版中提供了源码,文件为tomcat的bin/tomcat-native.tar.gz
,另外编译时候需要依赖APR 1.2、OpenSSL
,如果机器上没有安装,可以使用 yum -y install apr-devel openssl-devel
来进行安装。解压tomcat-native.tar.gz后会得到一个tomcat-native-1.1.20-src的目录,Native library的源文件位于tomcat-native-1.1.20-src/jni/native
下,进入该目录,执行./configure,可能会看到configure: error: APR could not be located. Please use the –with-apr option
的错误提示,这个时候用–with-apr制定一下apr的位置即可,我使用的是
./configure --with-apr=/usr/bin/apr-1-config
,顺利通过,然后执行 make && make install 编译就算搞定,此时应该可以在/usr/local/apr/lib/下看到一个名为libtcnative-1.so的文件,拷贝该文件到tomcat启动时提示的任何一个路径即可。
上面介绍了如果在window和linux下解决这个问题。最近使用mac os,也遇到了同样的问题,解决的办法和linux下相似,唯一不同的是在configure时需要指定java home,自己编译首要条件介绍已经安装了gcc,关于如果安装gcc,可以参考:mac os lion 安装gcc备忘,依赖的库似乎默认系统自带了,如果编译的时候提示缺少库,可以使用 port 方式来安装,顺便提一下 port 是一个和centos下的yum、ubuntu下的apt-get类似的包管理软件。我使用的configure参数设置如下:
./configure --with-apr=/usr/local/apr --with-java-home=/Library/Java/JavaVirtualMachines/jdk1.8.0_191.jdk/Contents/Home --with-ssl=/usr/local/Cellar/openssl/1.0.2s
然后使用
make&&make install
就编译完成。
如果成功,在目录/usr/local/apr/lib/下会生成一个名为libtcnative-1.0.dylib的库文件,使用ln命令做一个软链接到上述警告信息中提到的一个目录即可,例如:
ln -s /usr/local/apr/lib/libtcnative-1.dylib /Library/Java/Extensions/
$TOMCAT_HOME/bin/catalina.sh
文件,在虚拟机启动参数JAVA_OPTS中添加java.library.path参数,指定apr库的路径JAVA_OPTS="$JAVA_OPTS -Djava.library.path=/usr/local/apr/lib"
$TOMCAT_HOME/conf/server.xml
修改Connector标签里的protocol参数。<Connector port="8443" protocol="org.apache.coyote.http11.Http11AprProtocol"
maxThreads="150" SSLEnabled="true" >
cd /usr/local/tomcat/bin
./startup.sh
启动无报错,并如下图则成功
如果没有配置SSL相关参数,并且开启了SSL,启动时会发生org.apache.tomcat.jni.Error: 70023: This function has not been implemented on this platform
异常:
如果不想启用SSL,将server.xml中apr模式下ssl关闭将下边的SSLEngine="on"
更改为SSLEngine="off"
即可:
<Listener className="org.apache.catalina.core.AprLifecycleListener" SSLEngine="on" />
开启了apr之后,jvm用到的native内存会增大,因此要适当调大Metaspace空间,添加JVM选项:
-XX:MetaspaceSize=128m
下一篇讲解ab压力测试对NIO和APR的性能测试对比