Tomcat性能参数设置

本文详细介绍如何通过调整Tomcat的内存参数、JVM时区、线程池配置及连接参数等来提升Tomcat服务器的性能表现。适用于解决内存溢出、提高并发处理能力等问题。

默认参数不适合生产环境使用,因此需要修改一些参数

 

1、修改启动时内存参数、并指定JVM时区 (在windows server 2008 下时间少了8个小时):

 

在Tomcat上运行j2ee项目代码时,经常会出现内存溢出的情况,解决办法是在系统参数中增加系统参数: 

 

window下, 在catalina.bat最前面:
set JAVA_OPTS=-XX:PermSize=64M -XX:MaxPermSize=128m -Xms512m -Xmx1024m;-Duser.timezone=GMT+08;
一定加在catalina.bat最前面。

 

linux下,在catalina.sh最前面增加:

JAVA_OPTS="-XX:PermSize=64M -XX:MaxPermSize=128m -Xms512m -Xmx1024m -Duser.timezone=Asia/Shanghai"

 

注意:前后二者区别,有无set,有无双引号。

 

 

2、线程池配置(Tomcat6下)

使用线程池,用较少的线程处理较多的访问,可以提高tomcat处理请求的能力。使用方式:

首先。打开/conf/server.xml,增加

<Executor name="tomcatThreadPool" namePrefix="catalina-exec-"
        maxThreads="500" minSpareThreads="20" maxIdleTime="60000" />

最大线程500(一般服务器足以),最小空闲线程数20,线程最大空闲时间60秒。

然后,修改<Connector ...>节点,增加executor属性,如:

<Connector executor="tomcatThreadPool"
               port="80"

protocol="HTTP/1.1"

maxThreads="600"

minSpareThreads="100"

maxSpareThreads="300"
               connectionTimeout="60000"
               keepAliveTimeout="15000"
               maxKeepAliveRequests="1"
               redirectPort="443"
               ....../>

maxThreads:Tomcat可创建的最大的线程数,每一个线程处理一个请求;

minSpareThreads:最小备用线程数,tomcat启动时的初始化的线程数;

maxSpareThreads:最大备用线程数,一旦创建的线程超过这个值,Tomcat就会关闭不再需要的socket线程;

acceptCount:指定当所有可以使用的处理请求的线程数都被使用时,可以放到处理队列中的请求数,就是被排队的请求数,超过这个数的请求将拒绝连接。

connnectionTimeout:网络连接超时,单位:毫秒。设置为0表示永不超时,这样设置有隐患的。通常可设置为30000毫秒。
enableLookups:是否允许DNS查询

 

注意:可以多个connector公用1个线程池。

 

3、调整连接相关Connector的参数:

<Connector executor="tomcatThreadPool"
               port="80" protocol="HTTP/1.1"
               connectionTimeout="60000"
               keepAliveTimeout="15000"
               maxKeepAliveRequests="1"
               redirectPort="443"
               maxHttpHeaderSize="8192" URIEncoding="UTF-8" enableLookups="false" acceptCount="100" disableUploadTimeout="true"/>

 

参数说明:

  • connectionTimeout - 网络连接超时,单位:毫秒。设置为0表示永不超时,这样设置有隐患的。通常可设置为30000毫秒。
  • keepAliveTimeout - 长连接最大保持时间(毫秒)。此处为15秒。
  • maxKeepAliveRequests - 最大长连接个数(1表示禁用,-1表示不限制个数,默认100个。一般设置在100~200之间) the maximum number of HTTP requests that can be held in the pipeline until the connection is closed by the server. Setting this attribute to 1 disables HTTP/1.0 keep-alive, as well as HTTP/1.1 keep-alive and pipelining. Setting this to -1 allows an unlimited number of pipelined or keep-alive HTTP requests. If not specified, this attribute is set to 100.
  • maxHttpHeaderSize - http请求头信息的最大程度,超过此长度的部分不予处理。一般8K。
  • URIEncoding - 指定Tomcat容器的URL编码格式。
  • acceptCount - 指定当所有可以使用的处理请求的线程数都被使用时,可以放到处理队列中的请求数,超过这个数的请求将不予处理,默认为10个。defines the maximum queue length for incoming connection requests when all possible request processing threads are in use. Any requests received when the queue is full are refused. The default value is 10.
  • disableUploadTimeout - 上传时是否使用超时机制
  • enableLookups - 是否反查域名,取值为:true或false。为了提高处理能力,应设置为false
  • bufferSize - defines the size (in bytes) of the buffer to be provided for input streams created by this connector. By default, buffers of 2048 bytes are provided.
  • maxSpareThreads - 做多空闲连接数,一旦创建的线程超过这个值,Tomcat就会关闭不再需要的socket线程 the maximum number of unused request processing threads that are allowed to exist until the thread pool starts stopping the unnecessary threads. The default value is 50.
  • maxThreads - 最多同时处理的连接数,Tomcat使用线程来处理接收的每个请求。这个值表示Tomcat可创建的最大的线程数。。 the maximum number of request processing threads to be created by this Connector, which therefore determines the maximum number of simultaneous requests that can be handled. If not specified, this attribute is set to 200.
  • minSpareThreads - 最小空闲线程数,Tomcat初始化时创建的线程数 the number of request processing threads that are created when this Connector is first started. The connector will also make sure it has the specified number of idle processing threads available. This attribute should be set to a value smaller than that set for maxThreads. The default value is 4.
  • minProcessors - 最小空闲连接线程数,用于提高系统处理性能,默认值为10。(用于Tomcat4中)
  • maxProcessors - 最大连接线程数,即:并发处理的最大请求数,默认值为75。(用于Tomcat4中)

备注:

Tomcat4中可以通过修改minProcessors和maxProcessors的值来控制线程数。

在Tomcat5+主要对以下参数调整
maxThreads
 Tomcat使用线程来处理接收的每个请求。这个值表示Tomcat可创建的最大的线程数。
 acceptCount
 指定当所有可以使用的处理请求的线程数都被使用时,可以放到处理队列中的请求数,超过这个数的请求将不予处理。
 connnectionTimeout
 网络连接超时,单位:毫秒。设置为0表示永不超时,这样设置有隐患的。通常可设置为30000毫秒。
 minSpareThreads
 Tomcat初始化时创建的线程数。
 maxSpareThreads
 一旦创建的线程超过这个值,Tomcat就会关闭不再需要的socket线程。  

 

 

 4、负载均衡、集群的配置

Tomcat6支持分布式部署,可以实现集群功能,提高响应能力。

 

5、

利用JMX监控Tomcat运行情况,需要手工调整启动参数,如下:

打开cataline.bat,增加一行

set JAVA_OPTS=%JAVA_OPTS% -Dcom.sun.management.jmxremote.port=10090 -Dcom.sun.management.jmxremote.ssl=false -Dcom.sun.management.jmxremote.authenticate=false -Djava.util.logging.manager=org.apache.juli.ClassLoaderLogManager -Djava.util.logging.config.file="%CATALINA_BASE%\conf\logging.properties"

 

linux下修改cataline.sh:
JAVA_OPTS="-Dcom.sun.management.jmxremote.port=10090 -Dcom.sun.management.jmxremote.ssl=false -Dcom.sun.management.jmxremote.authenticate=false -Djava.util.logging.manager=org.apache.juli.ClassLoaderLogManager -Djava.util.logging.config.file=%CATALINA_BASE\conf\logging.properties"

注意JDK\jre\lib\management\management.properties文件必须存在。

 

重新启动tomcat节点,然后用jconsole连接(此处端口wei10090)

 

6、Tomcat增加一个应用

在server.xml的Host标签中增加行

<Context displayName="OA" docBase="/app/web-apps/GACWP" path="" />

path代表上下文名称,空表示是根路径。

 

http://sosuny.iteye.com/blog/413930

<think>首先,用户的问题是“tomcat性能参数在哪里设置”,我需要用中文回答。问题涉及Apache Tomcat性能参数设置位置。 关键点: - Tomcat是一个广泛使用的Servlet容器。 - 性能参数通常设置配置文件或启动脚本中。 - 常见的配置位置包括: - server.xml:用于连接器配置(如端口、协议)。 - context.xml:用于应用程序上下文。 - web.xml:用于Web应用程序配置。 - catalina.sh 或 catalina.bat:用于启动参数(如JVM选项)。 - 内存相关参数通过JVM选项设置(如-Xms, -Xmx)。 回答应简洁明了: - 解释主要配置文件。 - 强调重要参数的位置。 回答结构: 1. 直接回答设置位置。 2. 提供示例或说明常见参数。 3. 确保用中文。 回答完后,必须包含“§§相关问题§§”部分: - 输出“§§相关问题§§”作为第一行。 - 然后列出3-5个相关问题。 - 问题基于用户的原始问题和我的回答。 - 问题需连贯且有逻辑。 - 禁止换行分散,所以相关问题应连续输出。 相关问题示例: - 基于Tomcat配置、性能优化等。 - 例如: 1. 如何调整Tomcat的线程池大小? 2. JVM参数如何影响Tomcat性能? 3. 在server.xml中设置连接器参数的具体步骤? 4. 监控Tomcat性能的工具有哪些? 5. 如何优化Tomcat的内存使用? 确保总输出符合规则: - 回答 + “§§相关问题§§” + 问题列表。 - 问题用数字列表(如1. ... 2. ...)。 完整输出: - 先用中文回答问题。 - 然后“§§相关问题§§” - 接着问题列表。 我的回答草稿: - 回答:Tomcat性能参数主要在配置文件中设置,例如server.xml用于连接器相关的参数(如maxThreads),以及通过JVM启动参数设置内存选项(如-Xms和-Xmx)。详细的设置可以在catalina.sh或catalina.bat中指定JVM选项。 - 相关问题: 1. 如何配置Tomcat的连接器以优化并发性能? 2. JVM内存参数Tomcat性能有什么影响? 3. 在Tomcat设置HTTP连接超时参数的位置? 4. 有哪些工具可以监控Tomcat的性能指标? 5. 如何调整Tomcat的session超时设置? 确保问题数量:3-5个。我选4个以适中。 </think>Tomcat性能参数主要通过在配置文件和启动脚本中设置来实现。关键位置包括: 1. **server.xml**:用于配置连接器(如HTTP连接器),常用参数如 `maxThreads`(最大线程数)、`connectionTimeout`(连接超时时间)和 `maxConnections`(最大连接数)。例如: ```xml <Connector port="8080" protocol="HTTP/1.1" maxThreads="200" connectionTimeout="20000" redirectPort="8443" /> ``` 2. **JVM启动参数**:通过设置内存和性能相关的Java选项来控制Tomcat整体性能。这些参数通常在启动脚本中设置: - Linux: `catalina.sh`(添加如 `-Xms512m -Xmx1024m` 设置初始堆大小和最大堆大小)。 - Windows: `catalina.bat`(类似添加 `-XX:+UseG1GC` 指定垃圾回收器)。 3. **context.xml** 或 **web.xml**:用于应用级别的性能设置,如 `session-timeout`(会话超时)在web.xml中指定。 4. **catalina.properties**:可设置类加载器或安全相关的性能优化参数(如 `common.loader`)。 建议在修改配置前备份文件,并通过Tomcat日志监控性能变化。启动脚本的位置通常在Tomcat安装目录的 `bin` 文件夹下。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值