1、知识点扫盲java
什么是APR?
Apache Portable Runtime(APR)项目的任务是建立和维护软件库,为底层平台特定的实现提供可预测且一致的接口。主要目标是提供一个API,软件开发人员能够对其进行编码,并确保可预测的行为,若是不是相同的行为,不管其软件构建的平台如何,均可以减轻他们编写特殊状况的须要,以便解决或采起行动。平台特定缺陷或功能的优点。c++
2、tomcat的三种模式web
Tomcat的运行模式有3种,即BIO、NIO和APR。
一、BIO(blocking I/O)
即阻塞式I/O操做,表示Tomcat使用的是传统的Java I/O操做(即java.io包及其子包)。是基于JAVA的HTTP/1.1链接器,Tomcat7如下版本在默认状况下是以bio模式运行的。通常而言,bio模式是三种运行模式中性能最低的一种。咱们能够经过Tomcat Manager来查看服务器的当前状态。(Tomcat7 或如下,在 Linux 系统中默认使用这种方式。建议弃用,本模式已经被淘汰。
二、NIO(new I/O)
是Java SE 1.4及后续版本提供的一种新的I/O操做方式(即java.nio包及其子包)。Java nio是一个基于缓冲区、并能提供非阻塞I/O操做的Java API,所以nio也被当作是non-blocking I/O的缩写。它拥有比传统I/O操做(bio)更好的并发运行性能。利用 Java 的异步请求 IO 处理,能够经过少许的线程处理大量的请求。
想运行在该模式下,直接修改server.xml里的Connector节点,修改protocol为:
protocol="org.apache.coyote.http11.Http11NioProtocol"
2.五、NIO2(new I/O2)
就是NIO模式的加强版,功能和NIO同样,可是性能更强。
想运行在该模式下,直接修改server.xml里的Connector节点,修改protocol为:
protocol="org.apache.coyote.http11.Http11Nio2Protocol"
三、APR
安装起来最困难,可是从操做系统级别来解决异步的IO问题,大幅度的提升性能.
必需要安装apr和native,直接启动就支持apr。本文下面重点就是介绍怎么安装和启动APR。apache
3、安装APR前的官方要求vim
APR 1.2+ development headers (libapr1-dev package)
OpenSSL 1.0.2+ development headers (libssl-dev package)
JNI headers from Java compatible JDK 1.4+
GNU development environment (gcc, make)centos
4、本文生产环境以及系统要求tomcat
CentOS Linux release 7.6.1810 (Core)x86 64
(服务器必须是centos7版本,centos6以及6如下的版本不能使用APR)
Server version: Apache Tomcat/8.5.35
java version “1.8.0_191”安全
5、安装APR相关依赖包服务器
[root@APR ~]# yum -y install gcc gcc-c++ libtool* autoconf automake expat-devel perl perl-devel
6、下载安装包并发
[root@APR ~]# mkdir /software
[root@APR ~]# cd /software/
[root@APR software]# wget http://mirror.rise.ph/apache//apr/apr-1.6.5.tar.gz
[root@APR software]# wget http://mirror.rise.ph/apache//apr/apr-iconv-1.2.2.tar.gz
[root@APR software]# wget http://mirror.rise.ph/apache//apr/apr-util-1.6.1.tar.gz
[root@APR software]# wget https://www.openssl.org/source/old/1.1.1/openssl-1.1.1.tar.gz
友情提示:apr、apr-iconv、apr-util都是截止到2019年1月22日的最新版本,openssl是最新的稳定版,openssl的官网原文翻译以下:
最新的稳定版本是1.1.1系列。这也是咱们的长期支持(LTS)版本,支持到2023年9月11日。咱们以前的LTS版本(1.0.2系列)将继续获得支持,直到2019年12月31日(安全修复仅在支持的最后一年)。1.1.0系列目前仅接收安全修复程序,并将于2019年9月11日中止支持。鼓励1.0.2和1.1.0的全部用户尽快升级到1.1.1。0.9.8,1.0.0和1.0.1版本如今不受支持,不该使用。
所以,建议使用1.1.1版本,不要再使用其余版本!!!
7、安装APR
[root@APR software]# tar zxf apr-1.6.5.tar.gz
[root@APR software]# cd apr-1.6.5/
[root@APR apr-1.6.5]# vim configure
默认值:
在第30392行 RM='$RM'
修改成:
在第30392行 RM='$RM -f'
[root@APR apr-1.6.5]# ./configure --prefix=/usr/local/apr && make && make install
8、安装apr-iconv
[root@APR apr-1.6.5]# cd ..
[root@APR software]# tar zxf apr-iconv-1.2.2.tar.gz
[root@APR software]# cd apr-iconv-1.2.2/
[root@APR apr-iconv-1.2.2]# ./configure --prefix=/usr/local/apr-iconv --with-apr=/usr/local/apr && make && make install
9、安装apr-util
[root@APR apr-iconv-1.2.2]# cd ..
[root@APR software]# tar zxf apr-util-1.6.1.tar.gz
[root@APR software]# cd apr-util-1.6.1/
[root@APR apr-util-1.6.1]# ./configure --prefix=/usr/local/apr-util --with-apr=/usr/local/apr --with-apr-iconv=/usr/local/apr-iconv/bin/apriconv && make && make install
10、安装OpenSSL
[root@APR apr-util-1.6.1]# cd ..
[root@APR software]# tar zxf openssl-1.1.1.tar.gz
[root@APR software]# cd openssl-1.1.1/
[root@APR openssl-1.1.1]# ./config --prefix=/usr/local/openssl && make -j $(grep processor /proc/cpuinfo | wc -l) && make install
11、安装tomcat-native
[root@APR openssl-1.1.1]# cd /usr/local/tomcat/bin/
[root@APR bin]# tar zxf tomcat-native.tar.gz
[root@APR bin]# cd tomcat-native-1.2.18-src/native/
[root@APR native]# ./configure --with-ssl=/usr/local/openssl --with-apr=/usr/local/apr --with-java-home=/usr/local/java && make && make install
友情提示1:博主这里的jdk安装路径在/usr/local/java,是自定义环境,读者切莫直接粘贴,要改为你实际的jdk路径。
友情提示2:注意:若是以上 configure 失败,能够执行 make distclean 清除。
12、添加环境变量
[root@APR native]# vim /etc/profile.d/apr.sh
export LD_LIBRARY_PATH=/usr/local/apr/lib:$LD_LIBRARY_PATH
[root@APR native]# source /etc/profile.d/apr.sh
到此为止APR就安装完成了,下面咱们使用APR模式
十3、修改tomcat配置文件,使用APR运行模式,并测试是否安装成功
[root@APR native]# vim /usr/local/tomcat/conf/server.xml //请按你实际tomcat安装路径为准
默认值:69 Connector port="8080" protocol="HTTP/1.1" 70 connectionTimeout="20000" 71 redirectPort="8443"修改成:
69 Connector port="8080" protocol="org.apache.coyote.http11.Http11AprProtocol" 70 connectionTimeout="20000" 71 redirectPort="8443"默认值:
116 Connector port="8009" protocol="AJP/1.3" redirectPort="8443"修改成:
116 Connector port="8009" protocol="org.apache.coyote.ajp.AjpAprProtocol" redirectPort="8443"友情提示:若是你的服务器上没有使用apache,则能够把8009端口的那一行配置给注释掉。
十4、重启tomcat,并查看日志
[root@APR native]# /usr/local/tomcat/bin/shutdown.sh
[root@APR native]# /usr/local/tomcat/bin/startup.sh
[root@APR native]# tail -f /usr/local/tomcat/logs/catalina.out
22-Jan-2019 12:17:18.157 INFO [localhost-startStop-1] org.apache.catalina.startup.HostConfig.deployDirectory Deployment of web application directory [/usr/local/tomcat/webapps/docs] has finished in [11] ms
22-Jan-2019 12:17:18.157 INFO [localhost-startStop-1] org.apache.catalina.startup.HostConfig.deployDirectory Deploying web application directory [/usr/local/tomcat/webapps/examples]
22-Jan-2019 12:17:18.321 INFO [localhost-startStop-1] org.apache.catalina.startup.HostConfig.deployDirectory Deployment of web application directory [/usr/local/tomcat/webapps/examples] has finished in [163] ms
22-Jan-2019 12:17:18.321 INFO [localhost-startStop-1] org.apache.catalina.startup.HostConfig.deployDirectory Deploying web application directory [/usr/local/tomcat/webapps/host-manager]
22-Jan-2019 12:17:18.337 INFO [localhost-startStop-1] org.apache.catalina.startup.HostConfig.deployDirectory Deployment of web application directory [/usr/local/tomcat/webapps/host-manager] has finished in [16] ms
22-Jan-2019 12:17:18.337 INFO [localhost-startStop-1] org.apache.catalina.startup.HostConfig.deployDirectory Deploying web application directory [/usr/local/tomcat/webapps/manager]
22-Jan-2019 12:17:18.351 INFO [localhost-startStop-1] org.apache.catalina.startup.HostConfig.deployDirectory Deployment of web application directory [/usr/local/tomcat/webapps/manager] has finished in [14] ms
22-Jan-2019 12:17:18.354 INFO [main] org.apache.coyote.AbstractProtocol.start Starting ProtocolHandler ["http-apr-8080"]
22-Jan-2019 12:17:18.364 INFO [main] org.apache.coyote.AbstractProtocol.start Starting ProtocolHandler ["ajp-apr-8009"]
22-Jan-2019 12:17:18.366 INFO [main] org.apache.catalina.startup.Catalina.start Server startup in 474 ms
友情提示:查看日志看到“http-apr-8080”和“ajp-apr-8009”字样就是APR模式运行成功。
十5、查看日志可能出现的错误
INFO [main] org.apache.catalina.core.AprLifecycleListener.lifecycleEvent The APR based Apache Tomcat Native library which allows optimal performance in production environments was not found on the java.library.path: [/usr/java/packages/lib/amd64:/usr/lib64:/lib64:/lib:/usr/lib]
若是遇到这样的错误,解决办法以下(通常不会出现这样的错误,博主安装了不下10遍APR没出现这问题,这个问题来自一个同事的安装报错):
问题出现缘由:提示找不到基于APR的Apache Tomcat Native库,所以没法使用APR模式启动。
解决方案:
cp -R /usr/local/apr/lib/* /usr/lib64 cp -R /usr/local/apr/lib/* /usr/lib
而后再次重启tomcat便可!
十6、请支持正版博客地址,盗链可耻