共计 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 的下载地址:请点这里