`

<转>tomcat性能优化

 
阅读更多

1.精简Tomcat和配置文件 
1.删除不需要的管理应用和帮助应用,提高tomcat安全性。 

# 删除webapps下所有文件 

# rm –fr $CATALINA_HOME/webapps/* 

# 删除server/wenapps下所有文件 

# rm –fr $CATALINA_HOME/server/webapps/* 


2.精简sever.xml配置文件 

使用tomcat发布版本中的最小配置文件,提高性能,如果有功能上的需求,在逐个的加入功能配置。 

# 备份原来的server.xml为server.xml_bak 

# mv server.xml server.xml_bak 

# 复制server-minimal.xml为server.xml 

# cp server-minimal.xml server.xml 

2.连接器优化 
在$CATALINA_HOME/conf/server.xml配置文件中的Connetctor节点,和连接数相关的参数配置和优化。 

maxThreads 

Tomcat使用线程来处理接收的每个请求。这个值表示Tomcat可创建的最大的线程数。默认值200。 可以根据机器的时期性能和内存大小调整,一般可以在400-500。最大可以在800左右。 

acceptCount 


  指定当所有可以使用的处理请求的线程数都被使用时,可以放到处理队列中的请求数,超过这个数的请求将不予处理。默认值10。 
minSpareThreads 
Tomcat初始化时创建的线程数。默认值4。 

maxSpareThreads 
一旦创建的线程超过这个值,Tomcat就会关闭不再需要的socket线程。默认值50。 

enableLookups 

是否反查域名,默认值为true。为了提高处理能力,应设置为false 

connnectionTimeout 

网络连接超时,默认值20000,单位:毫秒。设置为0表示永不超时,这样设置有隐患的。通常可设置为30000毫秒。(本系统由于与后台系统接口超时时间较长,使用设置为60000) 
maxKeepAliveRequests 

保持请求数量,默认值100。 
bufferSize 
输入流缓冲大小,默认值2048 bytes。 

compression 

压缩传输,取值on/off/force,默认值off。 

其中和最大连接数相关的参数为maxThreads和acceptCount。如果要加大并发连接数,应同时加大这两个参数。web server允许的最大连接数还受制于操作系统的内核参数设置,通常Windows是2000个左右,Linux是1000个左右。 

1.maxThreads="150"       表示最多同时处理150个连接    
2.minSpareThreads="25"    表示即使没有人使用也开这么多空线程等待    
3.maxSpareThreads="75"    表示如果最多可以空75个线程,例如某时刻有80人访问,之后没有人访问了,则tomcat不会保留80个空线程,而是关闭5个空的。    
4.  
5.Count="100" 当同时连接的人数达到maxThreads时,还可以接收排队的连接,超过这个连接的则直接返回拒绝连接。               
6.  
7.      <Connector port="8080" protocol="HTTP/1.1"  connectionTimeout="20000" maxThreads="150"    
8.  
9.         minSpareThreads="25"    
10.  
11.         maxSpareThreads="75"    
12.  
13.       enableLookups="false"    
14.  
15.       acceptCount="100" debug="0"    
16.  
17.        disableUploadTimeout="true"  
18.       redirectPort="8443" URIEncoding="UTF-8"/>   
19.  
20.oding="UTF-8" 是设定JSP编码格式. 



Tomcat中如何禁止和允许列目录下的文件 


在$CATALINA_HOME/conf/web.xml中,把listings参数设置成false即可,如下: 

    listings 
    false 

    ... 


具体操作 


# vi $CATALINA_HOME/conf/server.xml 

修改用于AJP的连接: 

<Connector port="8009" protocol="AJP/1.3" /> 

为: 

<Connector port="8009" 

maxTreads="500" minSpareThreads="10" maxSpareThreads="50" 

acceptCount="50" connectionTimeout="60000" 

enableLookups="false" redirectPort="8443" protocol="AJP/1.3" /> 


修改通用连接: 

<Connector port="8080" /> 

为: 

<Connector port="8080" 

maxTreads="500" minSpareThreads="10" maxSpareThreads="50" 

acceptCount="50" connectionTimeout="60000" 

enableLookups="false" redirectPort="8443" protocol="AJP/1.3" 

compression="on" 

compressionMinSize="2048" 

noCompressionUserAgents="gozilla, traviata" 

compressableMimeType="text/html,text/xml"/> 


修改主机和应用配置: 

<Host name="localhost" appBase="webapps" /> 

为: 

<Host name="localhost" appBase=" " 

unpackWARs="true" autoDeploy="true" 

xmlValidation="false" xmlNamespaceAware="false"> 

<Context path="" docBase="/www/xxxx/site/web" reloadable="true" debug="0"/> 

</Host> 

3.优化JDK 
Tomcat默认可以使用的内存为128MB,Windows下,在文件{tomcat_home}/bin/catalina.bat,Unix下,在文件$CATALINA_HOME/bin/catalina.sh的前面,增加如下设置: 

JAVA_OPTS='$JAVA_OPTS -Xms[初始化内存大小] -Xmx[可以使用的最大内存] 
或 

设置环境变量:export JAVA_OPTS=”$JAVA_OPTS -Xms[初始化内存大小] -Xmx[可以使用的最大内存]” 

一般说来,你应该使用物理内存的 80% 作为堆大小。如果本机上有Apache服务器,可以先折算Apache需要的内存,然后修改堆大小。建议设置为70%;建议设置[[初始化内存大小]等于[可以使用的最大内存],这样可以减少平凡分配堆而降低性能。 


本例使用加入环境变量的方式: 

# vi /etc/profile 

加入:export JAVA_OPTS=”$JAVA_OPTS -Xms700 –Xmx700 

# source /etc/profile 


关键字: tomcat性能优化 
1.精简Tomcat和配置文件 
1.删除不需要的管理应用和帮助应用,提高tomcat安全性。 

# 删除webapps下所有文件 

# rm –fr $CATALINA_HOME/webapps/* 

# 删除server/wenapps下所有文件 

# rm –fr $CATALINA_HOME/server/webapps/* 


2.精简sever.xml配置文件 

使用tomcat发布版本中的最小配置文件,提高性能,如果有功能上的需求,在逐个的加入功能配置。 

# 备份原来的server.xml为server.xml_bak 

# mv server.xml server.xml_bak 

# 复制server-minimal.xml为server.xml 

# cp server-minimal.xml server.xml 

2.连接器优化 
在$CATALINA_HOME/conf/server.xml配置文件中的Connetctor节点,和连接数相关的参数配置和优化。 

maxThreads 

Tomcat使用线程来处理接收的每个请求。这个值表示Tomcat可创建的最大的线程数。默认值200。 可以根据机器的时期性能和内存大小调整,一般可以在400-500。最大可以在800左右。 

acceptCount 


  指定当所有可以使用的处理请求的线程数都被使用时,可以放到处理队列中的请求数,超过这个数的请求将不予处理。默认值10。 
minSpareThreads 
Tomcat初始化时创建的线程数。默认值4。 

maxSpareThreads 
一旦创建的线程超过这个值,Tomcat就会关闭不再需要的socket线程。默认值50。 

enableLookups 

是否反查域名,默认值为true。为了提高处理能力,应设置为false 

connnectionTimeout 

网络连接超时,默认值20000,单位:毫秒。设置为0表示永不超时,这样设置有隐患的。通常可设置为30000毫秒。(本系统由于与后台系统接口超时时间较长,使用设置为60000) 
maxKeepAliveRequests 

保持请求数量,默认值100。 
bufferSize 
输入流缓冲大小,默认值2048 bytes。 

compression 

压缩传输,取值on/off/force,默认值off。 

其中和最大连接数相关的参数为maxThreads和acceptCount。如果要加大并发连接数,应同时加大这两个参数。web server允许的最大连接数还受制于操作系统的内核参数设置,通常Windows是2000个左右,Linux是1000个左右。 

1.maxThreads="150"       表示最多同时处理150个连接    
2.minSpareThreads="25"    表示即使没有人使用也开这么多空线程等待    
3.maxSpareThreads="75"    表示如果最多可以空75个线程,例如某时刻有80人访问,之后没有人访问了,则tomcat不会保留80个空线程,而是关闭5个空的。    
4.  
5.Count="100" 当同时连接的人数达到maxThreads时,还可以接收排队的连接,超过这个连接的则直接返回拒绝连接。               
6.  
7.      <Connector port="8080" protocol="HTTP/1.1"  connectionTimeout="20000" maxThreads="150"    
8.  
9.         minSpareThreads="25"    
10.  
11.         maxSpareThreads="75"    
12.  
13.       enableLookups="false"    
14.  
15.       acceptCount="100" debug="0"    
16.  
17.        disableUploadTimeout="true"  
18.       redirectPort="8443" URIEncoding="UTF-8"/>   
19.  
20.oding="UTF-8" 是设定JSP编码格式. 



Tomcat中如何禁止和允许列目录下的文件 


在$CATALINA_HOME/conf/web.xml中,把listings参数设置成false即可,如下: 

    listings 
    false 

    ... 


具体操作 


# vi $CATALINA_HOME/conf/server.xml 

修改用于AJP的连接: 

<Connector port="8009" protocol="AJP/1.3" /> 

为: 

<Connector port="8009" 

maxTreads="500" minSpareThreads="10" maxSpareThreads="50" 

acceptCount="50" connectionTimeout="60000" 

enableLookups="false" redirectPort="8443" protocol="AJP/1.3" /> 


修改通用连接: 

<Connector port="8080" /> 

为: 

<Connector port="8080" 

maxTreads="500" minSpareThreads="10" maxSpareThreads="50" 

acceptCount="50" connectionTimeout="60000" 

enableLookups="false" redirectPort="8443" protocol="AJP/1.3" 

compression="on" 

compressionMinSize="2048" 

noCompressionUserAgents="gozilla, traviata" 

compressableMimeType="text/html,text/xml"/> 


修改主机和应用配置: 

<Host name="localhost" appBase="webapps" /> 

为: 

<Host name="localhost" appBase=" " 

unpackWARs="true" autoDeploy="true" 

xmlValidation="false" xmlNamespaceAware="false"> 

<Context path="" docBase="/www/xxxx/site/web" reloadable="true" debug="0"/> 

</Host> 

3.优化JDK 
Tomcat默认可以使用的内存为128MB,Windows下,在文件{tomcat_home}/bin/catalina.bat,Unix下,在文件$CATALINA_HOME/bin/catalina.sh的前面,增加如下设置: 

JAVA_OPTS='$JAVA_OPTS -Xms[初始化内存大小] -Xmx[可以使用的最大内存] 
或 

设置环境变量:export JAVA_OPTS=”$JAVA_OPTS -Xms[初始化内存大小] -Xmx[可以使用的最大内存]” 

一般说来,你应该使用物理内存的 80% 作为堆大小。如果本机上有Apache服务器,可以先折算Apache需要的内存,然后修改堆大小。建议设置为70%;建议设置[[初始化内存大小]等于[可以使用的最大内存],这样可以减少平凡分配堆而降低性能。 


本例使用加入环境变量的方式: 

# vi /etc/profile 

加入:export JAVA_OPTS=”$JAVA_OPTS -Xms700 –Xmx700 

# source /etc/profile 

分享到:
评论

相关推荐

    Java数据编程指南

    数据定义&lt;br&gt;基本数据操作&lt;br&gt;数据完整性&lt;br&gt;表达式&lt;br&gt;连接&lt;br&gt;合并&lt;br&gt;子...&lt;br&gt;Tomcat安装和配置&lt;br&gt;JRun 3.0安装和配置&lt;br&gt;安装检索&lt;br&gt;附录E 在WebLogic 6.0上配置并部署EJB&lt;br&gt;设置配置属性&lt;br&gt;生成EJB容器类&lt;br&gt;...

    Tomcat性能优化

    Tomcat7性能优化调优Tomcat7性能优化调优Tomcat7性能优化调优

    Tomcat性能优化.rar

    Tomcat性能优化.rar Tomcat性能优化.rar

    tomcat性能优化.pdf

    tomcat性能优化

    Tomcat性能优化笔记

    Tomcat性能优化可从外部环境和自身调整两方面着手。&lt;br&gt;外部环境主要是Tomcat所在服务器的运行环境,包括操作系统层面、部署以及Java虚拟机的配置

    Tomcat7性能优化

    通过优化tomcat提高网站的并发能力。服务器所能提供CPU、内存、硬盘的性能对处理能力有决定性影响。

    Java秒杀系统方案优化高性能高并发学习实战源代码以及笔记..zip

    Java秒杀系统方案优化高性能高并发学习实战源代码以及笔记..zip 章节笔记 第1章-课程介绍及项目框架搭建 知识点 使用spring boot 搭建项目基础框架 使用Thymeleaf做页面展示,封装Result统一结果 集成 mybatis + ...

    tomcat性能优化,调优

    tomcat性能优化 调优 tomcat 性能优化 优化详解 优化步骤 优化过程

    Tomcat性能优化.pdf

    Tomcat性能优化 1. 操作系统2. JAVA 虚拟机3. Tomcat 自身的调整策略

    tomcat7 优化 性能调优

    tomcat7 优化 性能调优,优化tomcat的配置,修改启动模式,开启并且使用线程池,JVM优化,图文说明

    tomcat性能优化

    tomcat性能优化,了解tomcat内部结构

    Tomcat7 性能优化

    Tomcat7性能优化.

    Tomcat7性能优化.docx

    09-27 Tomcat7性能优化

    WTS在线答题系统-其他

    优化用户答题性能(通过增加数据库表索引)&lt;/p&gt;&lt;p&gt;优化:取消答卷检查功能&lt;/p&gt;&lt;p&gt;功能:历史日志刪除功能&lt;/p&gt;&lt;p&gt;功能:增加下载操作日志功能&lt;/p&gt;&lt;p&gt;功能:增加后台操作日志记录功能:创建题目、修改题目、答卷管理、...

    Tomcat性能优化及JVM内存工作原理

    Tomcat性能优化及JVM内存工作原理,适用于运维人员,开发人员

    Tomcat性能优化1

    Tomcat性能优化设置tomcat的java虚拟机参数catalina.sh/batWindows下修改 $tomcat$\ bin \ catalina.

    tomcat性能优化.doc

    tomcat性能优化.doc

Global site tag (gtag.js) - Google Analytics