首页 > 其他 > 详细

tomcat调优

时间:2017-02-10 23:44:22      阅读:481      评论:0      收藏:0      [点我收藏+]

Java体系结构包括四个独立但相关的技术:

Java程序设计语言

Java class文件格式

Java API

Java VM


Tomcat不是一个完整意义上的Jave EE服务器,它甚至都没有提供对哪怕是一个主要Java EE API的实现;但由于遵守apache开源协议,tomcat却又为众多的java应用程序服务器嵌入自己的产品中构建商业的java应用程序服务器,如JBoss和JOnAS。尽管Tomcat对Jave EE API的实现并不完整,然而很企业也在渐渐抛弃使用传统的Java EE技术(如EJB)转而采用一些开源组件来构建复杂的应用。这些开源组件如Structs、Spring和Hibernate,而Tomcat能够对这些组件实现完美的支持。



调优

调整垃圾收集算法  内存(新生代空间、老生代空间、最大空间)


Tomcat包含了一个叫做Catalina的Servlet container(执行servlet和编译过的JSP)和一个JSP编译器(Jasper编译器)。事实上,一个包含了JSP编译器和Servlet容器的应用程序组合通过被称作Web容器。


JVM体系结构:

  • 两个子系统:

  • Class Loader 类加载器:用于读入Java源代码并将类加载到数据区。

  • Execution Engine 执行引擎:用来执行来自数据区的指令。

  • 两个组件

  • 运行时数据区:JVM的内存区域

  • 本地接口:即JNI,一个标准的java API,支持异构语言集成

数据区分为如下两种:

  • 所有线程共享数据区

  • 方法区(Method Area)

  • 堆(Heap)

  • 线程隔离的数据区,每个线程独占拥有

  • 虚拟机栈(VM stack)

  • 本地方法栈(Native Method Stack)

  • 程序计数器(Program Counter Register)


tomcat 参数设置

tomcat默认的参数配置是位开发环境定制的,所以内存和线程的配置都很低,如果直接应用在生产环境,很容易造成性能瓶颈;以下分别中JVM、线程池以及连接参数方面给出优化建议:


### 设置java的内存介于256m到1024m之间的命令

set JAVA_OPTS= -Xms256m -Xmx1024m    [此方法不太好]

 

  • JVM 优化

  • 当内存为8G时,建议配置:

  • JAVA_OPTS="-Dfile.encoding=UTF-8 -server -Xms6144m -Xmx6144m -XX:NewSize=1024m -XX:MaxNewSize=2048m -XX:PermSize=512m -XX:MaxPermSize=512m -XX:MaxTenuringThreshold=10 -XX:NewRatio=2 -XX:+DisableExplicitGC"

    • 当内存为16G时,建议配置:

  • JAVA_OPTS="-Dfile.encoding=UTF-8 -server -Xms13312m -Xmx13312m -XX:NewSize=3072m -XX:MaxNewSize=4096m -XX:PermSize=512m -XX:MaxPermSize=512m -XX:MaxTenuringThreshold=10 -XX:NewRatio=2 -XX:+DisableExplicitGC"

    • 当内存为32G时,建议配置:

  • JAVA_OPTS="-Dfile.encoding=UTF-8 -server -Xms29696m -Xmx29696m -XX:NewSize=6144m -XX:MaxNewSize=9216m -XX:PermSize=1024m -XX:MaxPermSize=1024m -XX:MaxTenuringThreshold=10 -XX:NewRatio=2 -XX:+DisableExplicitGC"

    • 参数解释

  • -Dfile.encoding:默认文件编码

  • -server:表示这是应用于服务器的配置,JVM内部会有特殊处理(GC策略,内存分配策略、以及并发处理能力等)

  • -Xmx1024m:设置JVM最大可用内存为1024MB

  • -Xms1024m:设置JVM最小内存为1024MB.此值可用设置与-Xmx相同,以避免每次垃圾回收完成后JVM重新分配内存。

  • -XX:NewSize:设置年轻代大小

  • -XX:MaxNewSize:设置最大年轻代大小

  • -XX:PermSize:设置永久代大小,默认是物理内存的1/64

  • -XX:MaxPermSize:设置最大永久代大小,默认物理内存的1/4(如果有大文件导出时,一定要设置该值和-XX:PermSize)

  • -XX:NewRatio=4:设置年轻代(包括Eden和两个Survivor区)与终身代的比值(除去永久代)。设置为4,则年轻代与终身代所占比值为1:4,年轻代占整个堆栈的1/5

  • -XX:MaxTenuringThreshold=10:设置垃圾最大年龄,默认为:15。如果设置为0的话,则年轻代对象不经过Survivor区,直接进入年老代。对于年老代比较多的应用,可以提高效率。如果将此值设置为一个较大值,则年轻代对象会在Survivor区进行多次复制,这样可以增加对象在年轻代的存活时间,增加在年轻代被回收的概率。

  • -XX:+DisableExplicitGC:这个将会忽略手动调用GC的代码,使得System.gc()的调用无效,完全不会触发任何GC

  • 线程池配置

  • <Executor name="tomcatThreadPool" namePrefix="catalina-exec-" maxThreads="500" minSpareThreads="100" prestarminSpareThreads="true" maxQueueSize="100" />

  • 参数解释

  • maxThreads:最大并发数,默认值200,一般建议在500~800,根据硬件设施和业务来判断。

  • minSpareThreads:Tomcat初始化时创建的线程数,默认为25

  • prestarminSpareThreads:在Tomcat初始化的时候就初始化minSpareThreads的参数值,如果不等于true,minSpareThreads的值就没啥效果了

  • maxQueueSize:最大的等待队列数,超过则拒绝请求

  • 修改连接参数

  • <Connector exexutor="tomcatThreadPool" port="8080" protocol="prg.apache.coyote.http11.http11Nio2Protocol"connectionTimeout="20000" maxConnections="10000"   redirectPort="8443" enableLookups="false" acceptCount="100" maxPostSize="10485760" compression="on" disableUploadTimeout="true" compressionMinSize="2048" acceptorThreadCount="2" compressableMimeType="text/html,text/xml,text/plain,text/css,text/javascript,application/javascript" YRIEncoding="utf-8" />

  • 参数解释

  • protocol:Tomcat6、7设置为nio更好:org.apache.coyote.http11.http11NioProtocol,Tomcat8的nio为:org.apache.coyote.http11.http11Nio2Protocol

  • enableLookups:禁用DNS查询

  • acceptCount:指定当所有可用处理请求的线程数都被使用时,可用房贷吹队列中的请求数,超过这个数的请求将不被吹,默认设置100

  • maxPostSize:以FORM URL参数方式的POST提交方式,限制提交最大的大小,默认为2097152(2M),它使用的单位是字节。如果要禁用限制,则可用设置为-1.

  • acceptorThreadCount:接受连接的线程数量,默认为1.一般这个值需要改动的时候是因为该服务器是一个多核CPU,如果是多核CPU一般配置为2.


本文出自 “流星工作室” 博客,请务必保留此出处http://redone.blog.51cto.com/5382451/1896785

tomcat调优

原文:http://redone.blog.51cto.com/5382451/1896785

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!