设为首页 收藏本站
查看: 2014|回复: 1

[经验分享] <转>Tomcat内存、连接数等性能参数设置

[复制链接]

尚未签到

发表于 2018-12-7 14:45:28 | 显示全部楼层 |阅读模式
  默认参数不适合生产环境使用,因此需要修改一些参数
  1、修改启动时内存参数、并指定JVM时区 (在windows server 2008 下时间少了8个小时):
  在Tomcat上运行j2ee项目代码时,经常会出现内存溢出的情况,解决办法是在系统参数中增加系统参数:
  window下, 在catalina.bat最前面:
  set JAVA_OPTS=-XX:PermSize=64M -XX:MaxPermSize=128m -Xms512m -Xmx1024m
  一定加在catalina.bat最前面。
  linux下,在catalina.sh最前面增加:
  JAVA_OPTS=&quot;-XX:PermSize=64M -XX:MaxPermSize=128m -Xms512m -Xmx1024m -Duser.timezone=Asia/Shanghai&quot;
  注意:前后二者区别,有无set,有无双引号。
  2、线程池配置(Tomcat6下)
  使用线程池,用较少的线程处理较多的访问,可以提高tomcat处理请求的能力。使用方式:
  首先。打开/conf/server.xml,增加
Xml代码  http://leon1509.iteye.com/images/icon_star.png


  最大线程500(一般服务器足以),最小空闲线程数20,线程最大空闲时间60秒。
  然后,修改节点,增加executor属性,如:
Xml代码  http://leon1509.iteye.com/images/icon_star.png


  maxThreads:Tomcat可创建的最大的线程数,每一个线程处理一个请求;
  minSpareThreads:最小备用线程数,tomcat启动时的初始化的线程数;
  maxSpareThreads:最大备用线程数,一旦创建的线程超过这个值,Tomcat就会关闭不再需要的socket线程;
  acceptCount:指定当所有可以使用的处理请求的线程数都被使用时,可以放到处理队列中的请求数,就是被排队的请求数,超过这个数的请求将拒绝连接。
  connnectionTimeout:网络连接超时,单位:毫秒。设置为0表示永不超时,这样设置有隐患的。通常可设置为30000毫秒。
  enableLookups:是否允许DNS查询
  注意:可以多个connector公用1个线程池。
  3、调整连接相关Connector的参数:
Xml代码  http://leon1509.iteye.com/images/icon_star.png


  参数说明:
  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>  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>  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=&quot;%CATALINA_BASE%\conf\logging.properties&quot;
  linux下修改cataline.sh:
  JAVA_OPTS=&quot;-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&quot;
  注意JDK\jre\lib\management\management.properties文件必须存在。
  重新启动tomcat节点,然后用jconsole连接(此处端口wei10090)
  6、Tomcat增加一个应用
  在server.xml的Host标签中增加行
Xml代码  http://leon1509.iteye.com/images/icon_star.png


  path代表上下文名称,空表示是根路径。
  补充:
Xml代码  http://leon1509.iteye.com/images/icon_star.png


  maxThreads=&quot;150&quot;     表示最多同时处理150个连接
  minSpareThreads=&quot;25&quot;     表示即使没有人使用也开这么多空线程等待
  maxSpareThreads=&quot;75&quot;     表示如果最多可以空75个线程,例如某时刻有80人访问,之后没有人访问了,则tomcat不会保留80个空线程,而是关闭5个空的。
  acceptCount=&quot;100&quot;   当同时连接的人数达到maxThreads时,还可以接收排队的连接,超过这个连接的则直接返回拒绝连接


运维网声明 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-644415-1-1.html 上篇帖子: Tomcat中JSP预编译处理Jasper 2 JSP Engine-J2EE 下篇帖子: 【实战】 Linux服务器安装配置Tomcat6的Admin模块详细步骤

尚未签到

发表于 2021-3-11 08:51:03 | 显示全部楼层
请问下:位置cygwin=false前。
JAVA_OPTS="-server -Xms256m -Xmx512m -XX:PermSize=64M -XX:MaxPermSize=128m"
这样修改跟您的有什么区别?

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

回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

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

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

扫描微信二维码查看详情

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


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


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


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



合作伙伴: 青云cloud

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