阿里云-云小站(无限量代金券发放中)
【腾讯云】云服务器、云数据库、COS、CDN、短信等热卖云产品特惠抢购

Tomcat常用参数设置

232次阅读
没有评论

共计 2702 个字符,预计需要花费 7 分钟才能阅读完成。

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

SSL Handshake        Blocking                    Non blocking                  Blocking

Max Connections      maxThreads                  See polling size              See polling size

在 Ubuntu 12.04 LTS 上通过 Tomcat 部署 Solr 4 http://www.linuxidc.com/Linux/2012-09/71158.htm

Ubuntu 下部署 Solr(4.4)到 Tomcat(7.0.53) http://www.linuxidc.com/Linux/2014-05/101443.htm

Linux 下 Apache 与多个 Tomcat 集群负载均衡 http://www.linuxidc.com/Linux/2012-01/51731.htm

Nginx Tomcat 集群负载均衡解决笔记 http://www.linuxidc.com/Linux/2013-07/86827.htm

实例详解 Tomcat 组件安装 +Nginx 反向代理 Tomcat+Apache 使用 mod_jk 和 mod_proxy 反向代理和负载均衡 http://www.linuxidc.com/Linux/2013-06/85290.htm

CentOS 6.5 下利用 Rsyslog+LogAnalyzer+MySQL 部署日志服务器 http://www.linuxidc.com/Linux/2014-06/103836.htm

Apache+Tomcat 环境搭建(JK 部署过程)http://www.linuxidc.com/Linux/2012-11/74474.htm

Tomcat 的详细介绍:请点这里
Tomcat 的下载地址:请点这里

正文完
星哥玩云-微信公众号
post-qrcode
 0
星锅
版权声明:本站原创文章,由 星锅 于2022-01-20发表,共计2702字。
转载说明:除特殊说明外本站文章皆由CC-4.0协议发布,转载请注明出处。
【腾讯云】推广者专属福利,新客户无门槛领取总价值高达2860元代金券,每种代金券限量500张,先到先得。
阿里云-最新活动爆款每日限量供应
评论(没有评论)
验证码
【腾讯云】云服务器、云数据库、COS、CDN、短信等云产品特惠热卖中