Tomcat在各位JavaWeb从业者常常就是默认的开发环境,但是Tomcat的默认配置作为生产环境,尤其是内存和线程的配置,默认都很低,容易成为性能瓶颈。
思路说明
Tomat主要参考资料有:http://tomcat.apache.org/tomcat-8.0-doc/config/ajp.html,
具体思路如下:
1. 调整tomcat的thread最大连接数的默认值,默认最高200。
2. 修改tomcat的系统连接模型有BIO改为APR模型。
3. 修改APR插件以优化tomcat的线程管理性能。
APR是从操作系统级别来解决异步的IO问题,大幅度的提高性能. (http://apr.apache.org/).
APR(Apache Portable Runtime)是一个高可移植库,它是Apache HTTP Server 2.x的核心.能更好地和其它本地web技术集成,总体上让Java更有效率作为一个高性能web服务
平台而不是简单作为后台容器.
在产品环境中,特别是直接使用Tomcat做WEB服务器的时候,应该使用Tomcat Native来提高其性能.如果不配APR,基本上300个线程狠快就会用满,以后的请求就只好等待,但是配上APR之后,并发的线程数量明显下降,从原来的300可能会马上下降到只有几十,新的请求会毫无阻塞的进来.
在局域网环境测,就算是400个并发,也是一瞬间就处理/传输完毕,但是在真实的Internet环境下,页面处理时间只占0.1%都不到,绝大部分时间都用来页面传输.如果不用APR,一个线程同一时间只能处理一个用户,势必会造成阻塞。所以生产环境下用apr是非常必要的.
JVM优化
-server -Xms2048M -Xmx2048M -Xmn512M -XX:MaxDirectMemorySize=256m -XX:MaxTenuringThreshold=1 -XX:SurvivorRatio=30 -XX:TargetSurvivorRatio=50 -Xnoclassgc -Xss256K -XX:+PrintGCDetails -XX:+PrintGCTimeStamps -XX:PermSize=256m -XX:MaxPermSize=256m -XX:+UseParNewGC -XX:+UseConcMarkSweepGC -XX:CMSInitiatingOccupancyFraction=80 -XX:ParallelGCThreads=4 -XX:ConcGCThreads=4 -XX:+CMSParallelRemarkEnabled -XX:+CMSScavengeBeforeRemark -XX:+ExplicitGCInvokesConcurrent -XX:+UseTLAB -XX:TLABSize=64K
优化server.xml
修改server.xml文件,关键核心修改值是
<Connector port="8080" protocol="org.apache.coyote.http11.Http11AprProtocol" maxThreads="2000" minSpareThreads="100" maxSpareThreads="1000" acceptCount="1000"
connectionTimeout="20000"
redirectPort="8443" />
APR安装
Tomcat8/0应该下载1.1.x的版本。具体下载地址:http://mirrors.cnnic.cn/apache/tomcat/tomcat-connectors/native/1.1.34/source/tomcat-native-1.1.34-src.tar.gz
安装步骤如下,默认安装地址:/usr/local/安装依赖
#yum install apr-devel openssl-devel gcc-c++
安装tomcat-native
#tar -xvf tomcat-native-1.1.34-src.tar.gz
#cd tomcat-native-1.1.34-src/jni/native/
#./configure --with-apr=/usr/bin/apr-1-config \
--with-java-home=/usr/java/jdk1.8.0_111/ \
--with-ssl=yes \
--prefix=$CATALINA_HOME
#make
#make install
当三个优化完毕之后,重新启动tomcat。当看到
INFO [main] org.apache.coyote.AbstractProtocol.start Starting ProtocolHandler ["http-apr-8080"]
INFO [main] org.apache.coyote.AbstractProtocol.start Starting ProtocolHandler ["ajp-apr-8009"]
如下字样,则说明tomcat性能优化已经完成。