Tomcat优化

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 
  1. -server:一定要作为第一个参数,在多个CPU时性能佳
  2. -Xms:设置JVM最大可用内存。 默认是物理内存的1/64,一般设置为服务器配置的内存。
  3. -Xmx:java heap最大值,此值可以设置与-Xmx相同,以避免每次垃圾回收完成后JVM重新分配内存。
  4. -XX:PermSize:设定内存的永久保存区初始大小。缺省值为64M。
  5. -XX:MaxPermSize:设定内存的永久保存区最大 大小。缺省值为64M。
  6. -Xmn:young generation(年轻代)的heap大小。一般设置为Xmx的3、4分之一
  7. -XX:NewRatio=4:设置年轻代(包括Eden和两个Survivor区)与年老代的比值(除去持久代)。设置为4,则年轻代与年老代所占比值为1:4,年轻代占整个堆栈的1/5
  8. -XX:SurvivorRatio=4:设置年轻代中Eden区与Survivor区的大小比值。设置为4,则两个Survivor区与一个Eden区的比值为2:4,一个Survivor区占整个年轻代的1/6
  9. -XX:MaxPermSize=16m:设置持久代大小为16m。
  10. -verbose:gc:显示垃圾收集信息(在虚拟机发生内存回收时在输出设备显示信息)
  11. UseConcMarkSweepGC:设置年老代为并发收集。
  12. -XX:MaxTenuringThreshold=0:设置垃圾最大年龄。如果设置为0的话,则年轻代对象不经过Survivor区,直接进入年老代。对于年老代比较多的应用,可以提高效率。如果将此值设置为一个较大值,则年轻代对象会在Survivor区进行多次复制,这样可以增加对象再年轻代的存活时间,增加在年轻代即被回收的概论。
  13. -XX:+UseParallelGC:年轻代垃圾收集器为并行收集器。
  14. -XX:MaxGCPauseMillis=100:设置每次年轻代垃圾回收的最长时间,如果无法满足此时间,JVM会自动调整年轻代大小,以满足此值。
  15. -XX:+UseAdaptiveSizePolicy:设置此选项后,并行收集器会自动选择年轻代区大小和相应的Survivor区比例,以达到目标系统规定的最低相应时间或者收集频率等,此值建议使用并行收集器时,一直打开。
  16. CMSInitiatingOccupancyFraction:触发CMS收集器的内存比例。比如60%的意思就是说,当内存达到60%,就会开始进行CMS并发收集。
  17. CMSFullGCsBeforeCompaction:设置在几次CMS垃圾收集后,触发一次内存整理。
  18. -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 的页面

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

今朝花落悲颜色

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值