Tomcat常用参数设置

来源:互联网 发布:淘宝延长收货怎么用 编辑:程序博客网 时间:2024/06/05 01:00
tomcat的默认值在一般情况下都是性能最好的选择,除了堆栈内存外
启动tomcat时设置的内存参数及设置准则:
-Xms   设置JVM启动时的堆栈内存的大小
-Xmx   设置JVM最大的堆栈内存大小
一般都建议将这两个值设置成一样大小,因为重新分配时会耗费性能。

内存设置过小,会导致tomcat运行过慢,或者容易报OutOfMemoryError错误信息,使运行不正常。

内存设置过大,可能出现系统无法分配如此多内存而导致启动tomcat失败,要么正常启动,但耗费过多计算机内存,使其他应用程序无法正常运行。

JVM常用参数:
-XX:+PrintGCDetails  打印垃圾回收信息
-Xms 为Heap区域的初始值,线上环境需要与-Xmx设置为一致,否则capacity的值会来回飘动
-Xmx 为Heap区域的最大值
-Xss(或-ss) 线程栈大小(指一个线程的native空间)1.5以后是1M的默认大小
-XX:PermSize与-XX:MaxPermSize  方法区(永久代)的初始大小和最大值(但不是本地方法区)
-XX:NewRatio  老年代与新生代比率
-XX:SurvivorRatio  Eden与Survivor的占用比例。例如8表示,一个survivor区占用 1/8 的Eden内存,即1/10的新生代内存,为什么不是1/9?因为我们的新生代有2个survivor,即S1和S22。所以survivor总共是占用新生代内存的 2/10,Eden与新生代的占比则为 8/10。
-XX:MaxHeapFreeRatio  GC后,如果发现空闲堆内存占到整个预估的比例小于这个值,则减小堆空间。
-XX:MinHeapFreeRatio  GC后,如果发现空闲堆内存占到整个预估的比例大于这个值,则增大堆空间。
-XX:NewSize    新生代大小

线程数设置

connector 的maxThread:同时请求的最大线程数(即同时请求客户端数)
在性能测试中经常出现同时并发数大于maxThread,但所有请求都能成功的情况,因为超过最大线程数的请求会等待,如果等待时间没有超过链接的timeout时间,都会成功。
为了防止流量暴增或黑客攻击使系统超出JVM最大的内存限制,所以需要设置maxThread。
如何将这些参数设置为最佳值
最好的方式是设置不同的值后,仿真网络流量进行测试,观察响应时间和内存占用情况。每一种机器与JVM的组合都会有不同的表现。

tomcat的三种连接方式:
JIO(java.io)
默认的链接方式,也称为“coyote”。http和ajp的模块化实现。

APR(Apache Portable Runtime)

安装起来最困难,但是从操作系统级别来解决异步的IO问题,大幅度的提高性能.
必须要安装apr和native,然后修改protocol为org.apache.coyote.http11.Http11AprProtocol。


NIO(java.nio)

也是用纯java编写的连接器。该实现用java.nio核心java网络类以提供非阻塞的TCP包特性。这种Connector设计的主要目标是用非阻塞(nonblocking)的方式部分实现connector,以达到使用很少的线程给tomcat管理提供比JIO Connector执行效果更好的Connector实现。另一方面,NIO Connector只需要一个线程就能分析众多连接器的请求,但每个请求随后必须运行自身线程才能寻到servlet。因为部分请求处理是以非阻塞的java代码完成的,因此,部分请求处理所占用的时间是java线程不需处于在用状态的时间,这意味着更小的线程池能用于处理相同数量的并发请求。小线程池也意味着低CPU占用,轮流使用该线程池意味着获得更好的性能。某些情况的并发请求,NIO效率更好,而另外一些情况,则更差。

<Connector port="8080" protocol="HTTP/1.1" 
               connectionTimeout="20000" 
               redirectPort="8443" />
  改为
 <Connector port="8080" protocol="org.apache.coyote.http11.Http11NioProtocol" 
               connectionTimeout="20000" 
               redirectPort="8443" />

经过使用ab进行并发测试,默认JIO配置下300个并发都会有问题,设置成NIO方式后,起码可以支持1500个并发


最后贴上官方文档上对tomcat的三种Connector的方式做一个简单比较

              Java Blocking Connector       Java Nio Blocking Connector       APR ConnectorClassname         Http11Protocol                  Http11NioProtocol         Http11AprProtocolTomcat Version   3.x 4.x 5.x 6.x                       6.x                     5.5.x 6.xSupport Polling         NO                             YES                        YESPolling Size           N/A                   Unlimited - Restricted by mem        UnlimitedRead HTTP Request     Blocking                     Blocking                       BlockingRead HTTP Body        Blocking                     Blocking                       BlockingWrite HTTP Response   Blocking                     Blocking                       BlockingSSL Support           Java SSL                     Java SSL                       OpenSSLSSL Handshake         Blocking                     Non blocking                   BlockingMax Connections       maxThreads                   See polling size               See polling size

0 0
原创粉丝点击