设为首页 收藏本站
查看: 704|回复: 0

[经验分享] tomcat调优

[复制链接]
累计签到:1 天
连续签到:1 天
发表于 2017-2-13 14:38:54 | 显示全部楼层 |阅读模式
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.




运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-341667-1-1.html 上篇帖子: httpd+tomcat cluster 下篇帖子: 解决Linux下启动Tomcat遇到Neither the JAVA_HOME nor the JRE_HOME enviro...
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表