Tomcat常用参数设置

Tomcat的默认值在一般情况下都是性能最好的选择,除了堆栈内存外
启动tomcat时设置的内存参数及设置准则:
-Xms  设置JVM启动时的堆栈内存的大小
-Xmx  设置JVM最大的堆栈内存大小
一般都建议将这两个值设置成一样大小,因为重新分配时会耗费性能。

内存设置过小,会导致tomcat运行过慢,或者容易报OutOfMemoryError错误信息,使运行不正常。
内存设置过大,可能出现系统无法分配如此多内存而导致启动tomcat失败,要么正常启动,但耗费过多计算机内存,使其他应用程序无法正常运行。

线程数设置

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 Connector

Classname        Http11Protocol                  Http11NioProtocol        Http11AprProtocol

Tomcat Version  3.x 4.x 5.x 6.x                      6.x                    5.5.x 6.x

Support Polling        NO                            YES                        YES

Polling Size          N/A                  Unlimited - Restricted by mem        Unlimited

Read HTTP Request    Blocking                    Blocking                      Blocking

Read HTTP Body        Blocking                    Blocking                      Blocking

Write HTTP Response  Blocking                    Blocking                      Blocking

SSL Support          Java SSL                    Java SSL                      OpenSSL

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:https://www.heiqu.com/ef28d62142b2245992183fc3af741151.html