Tomcat优化分为内存优化、线程优化、IO优化和APR(APR是从操作系统级别来解决异步的IO问题,大幅度的提高性能)
一:Tomcat内存优化,启动时告诉JVM我要一块大内存(调优内存是最直接的方式)
在bin目录下面的catalina.sh中添加如下
JAVA_OPTS=-server -Xms8192m -Xmx8192m -Xmn1890m -XX:NewRatio=4 -XX:SurvivorRatio=4 -XX:MaxPermSize=16m -verbose:gc -XX:+UseConcMarkSweepGC -XX:MaxTenuringThreshold=0 -XX:+UseParallelGC XX:MaxGCPauseMillis=100 -XX:+UseAdaptiveSizePolicy -XX:CMSInitiatingOccupancyFraction=70 -XX:CMSFullGCsBeforeCompaction=0 -Xnoclassgc
- -server:一定要作为第一个参数,在多个CPU时性能佳
- -Xms:设置JVM最大可用内存。 默认是物理内存的1/64,一般设置为服务器配置的内存。
- -Xmx:java heap最大值,此值可以设置与-Xmx相同,以避免每次垃圾回收完成后JVM重新分配内存。
- -XX:PermSize:设定内存的永久保存区初始大小。缺省值为64M。
- -XX:MaxPermSize:设定内存的永久保存区最大 大小。缺省值为64M。
- -Xmn:young generation(年轻代)的heap大小。一般设置为Xmx的3、4分之一
- -XX:NewRatio=4:设置年轻代(包括Eden和两个Survivor区)与年老代的比值(除去持久代)。设置为4,则年轻代与年老代所占比值为1:4,年轻代占整个堆栈的1/5
- -XX:SurvivorRatio=4:设置年轻代中Eden区与Survivor区的大小比值。设置为4,则两个Survivor区与一个Eden区的比值为2:4,一个Survivor区占整个年轻代的1/6
- -XX:MaxPermSize=16m:设置持久代大小为16m。
- -verbose:gc:显示垃圾收集信息(在虚拟机发生内存回收时在输出设备显示信息)
- UseConcMarkSweepGC:设置年老代为并发收集。
- -XX:MaxTenuringThreshold=0:设置垃圾最大年龄。如果设置为0的话,则年轻代对象不经过Survivor区,直接进入年老代。对于年老代比较多的应用,可以提高效率。如果将此值设置为一个较大值,则年轻代对象会在Survivor区进行多次复制,这样可以增加对象再年轻代的存活时间,增加在年轻代即被回收的概论。
- -XX:+UseParallelGC:年轻代垃圾收集器为并行收集器。
- -XX:MaxGCPauseMillis=100:设置每次年轻代垃圾回收的最长时间,如果无法满足此时间,JVM会自动调整年轻代大小,以满足此值。
- -XX:+UseAdaptiveSizePolicy:设置此选项后,并行收集器会自动选择年轻代区大小和相应的Survivor区比例,以达到目标系统规定的最低相应时间或者收集频率等,此值建议使用并行收集器时,一直打开。
- CMSInitiatingOccupancyFraction:触发CMS收集器的内存比例。比如60%的意思就是说,当内存达到60%,就会开始进行CMS并发收集。
- CMSFullGCsBeforeCompaction:设置在几次CMS垃圾收集后,触发一次内存整理。
- -Xnoclassgc:禁用类垃圾回收,性能会高一点;
堆就是Java代码可及的内存,是留给开发人员使用的;非堆就是JVM留给 自己用的,所以方法区、JVM内部处理或优化所需的内存(如JIT编译后的代码缓存)、每个类结构(如运行时常数池、字段和方法数据)以及方法和构造方法 的代码都在非堆内存中。
二:Tomcat 线程优化
在server.xml中
<Connector port="80" protocol="HTTP/1.1" maxThreads="600"
minSpareThreads="100"
maxSpareThreads="500"
acceptCount="700"
connectionTimeout="20000"/>
maxThreads="X" 表示最多同时处理X个连接
minSpareThreads="X" 初始化X个连接
maxSpareThreads="X" 表示如果最多可以有X个线程,一旦超过X个,则会关闭不在需要的线程
acceptCount="X" 当同时连接的人数达到maxThreads时,还可以排队,队列大小为X.超过X就不处理
三:Tomcat IO优化
1:Java BIO : 同步并阻塞,服务器实现模式为一个连接一个线程,即客户端有连接请求时服务器端就需要启动一个线程进行处理,如果这个连接不做任何事情会造成不必要的线程开销,当然可以通过线程池机制改善。
2:JAVA NIO:又分为同步非阻塞IO,异步阻塞IO 与BIO最大的区别one request one thread.可以复用同一个线程处理多个connection(多路复用).
3.Java AIO(NIO.2) : 异步非阻塞,服务器实现模式为一个有效请求一个线程,客户端的I/O请求都是由OS先完成了再通知服务器应用去启动线程进行处理
BIO、NIO、AIO适用场景分析:
BIO方式适用于连接数目比较小且固定的架构,这种方式对服务器资源要求比较高,并发局限于应用中,JDK1.4以前的唯一选择,但程序直观简单易理解.
NIO方式适用于连接数目多且连接比较短(轻操作)的架构,比如聊天服务器,并发局限于应用中,编程比较复杂,JDK1.4开始支持.
AIO方式使用于连接数目多且连接比较长(重操作)的架构,比如相册服务器,充分调用OS参与并发操作,编程比较复杂,JDK7开始支持.
bio server.xml 配置 ,一般默认的就是BIO(重启生效)
<Connector port="8080" protocol="HTTP/1.1"
connectionTimeout="20000"
redirectPort="8443" />
nio server.xml 配置 (重启生效)
<Connector port="8080" protocol="org.apache.coyote.http11.Http11NioProtocol"
connectionTimeout="20000"
redirectPort="8443" />
apr server.xml 配置 (重启生效)
<Connector port="8080" protocol="org.apache.coyote.http11.Http11AprProtocol"
connectionTimeout="20000"
redirectPort="8443" />
apr模式还需要安装 apr 、 apr-utils 、tomcat-native包
apr版本地址:http://archive.apache.org/dist/apr/
1.安装apr
sudo yum -y install make gcc gcc-c++ kernel-devel m4 ncurses-devel openssl-devel
wget http://archive.apache.org/dist/apr/apr-1.5.1.tar.gz
tar -zxvf
cd apr-1.5.1
./configure --prefix=/usr/local/apr && make && make install
2.安装apr-util
wget http://archive.apache.org/dist/apr/apr-util-1.5.1.tar.gz
tar -zxvf apr-util-1.5.1.tar.gz
cd apr-util-1.5.1
./configure --with-apr=/usr/local/apr/ --prefix=/usr/local/apr-utils && make && make install
3.tomcat-native安装
进入到tomcat目录
cd tomcat7/bin
tar -zxvf tomcat-native.tar
cd tomcat-native-1.2.23-src/native
./configure --with-apr=/usr/local/apr
//出现如下错误 //Found OPENSSL_VERSION_NUMBER 0x1000105f (OpenSSL 1.0.1e 11 Feb 2013) //Require OPENSSL_VERSION_NUMBER 0x1000200f or greater (1.0.2) //configure: error: Your version of OpenSSL is not compatible with this version of tcnative
当前的yum 库只有1.0.1 的OpenSSL,所以我们需要手工安装1.0.2
wget https://www.openssl.org/source/openssl-1.0.2-latest.tar.gz
tar -xzxf openssl-1.0.2-latest.tar.gz
cd openssl-1.0.2
./config --prefix=/usr/local/openssl -fPIC&& make && make install // 注意这里需要加入 -fPIC参数,否则后面在安装tomcat native 组件会出错 /
4.重新安装 tomcat-native组件
cd usr/local/tomcat7/tomcat-native-1.2.17-src/native
./configure --with-apr=/usr/local/apr --with-ssl=/usr/local/openssl&& make && make install
server.xml 修改为
<Connector port="8080" protocol="org.apache.coyote.http11.Http11AprProtocol"
connectionTimeout="20000"
redirectPort="8443" />
5.添加环境变量
vi /etc/profile
export LD_LIBRARY_PATH=/usr/local/apr/lib
source /etc/profile
启动tomcat,可以看到是apr模式启动
在tomcat-users.xml添加用户
<role rolename="manager-gui"/>
<user username="tomcat" password="s3cret" roles="manager-gui"/>
浏览器输入http://192.168.204.133:8080/manager/status,查看apr 的页面