设为首页 收藏本站
查看: 273|回复: 0

[经验分享] <转>tomcat性能优化

[复制链接]

尚未签到

发表于 2017-1-21 11:16:52 | 显示全部楼层 |阅读模式
  
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 

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-331544-1-1.html 上篇帖子: (转载)tomcat优化总结 下篇帖子: Tomcat 性能优化(转)
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表