文档章节

Tomcat修改service.xml性能调优 增加最大并发连接数

完美世界
 完美世界
发布于 2014/06/04 20:27
字数 2661
阅读 81
收藏 3
  1. Tomcat的外部调优

    • JAVA虚拟机(JVM)性能优化,可以通过以下两个参数来设置虚拟机使用内存的大小,-Xms<size>(JVM初始化堆的大小)和-Xmx<size>(JVM堆的最大值)。

    • 这两个值的大小一般根据需要进行设置。初始化堆的大小执行了虚拟机在启动时向系统申请的内存的大小。一般而言,这个参数不重要。但是有的应用程序在大负载的情况下会急剧地占用更多的内存,此时这个参数就是显得非常重要,如果虚拟机启动时设置使用的内存比较小而在这种情况下有许多对象进行初始化,虚拟机就必须重复地增加内存来满足使用。由于这种原因,我们一般把-Xms和-Xmx设为一样大,而堆的最大值受限于系统使用的物理内存。一般使用数据量较大的应用程序会使用持久对象,内存使用有可能迅速地增长。当应用程序需要的内存超出堆的最大值时虚拟机就会提示内存溢出,并且导致应用服务崩溃。因此一般建议堆的最大值设置为可用内存的最大值的80%。

    • Tomcat默认可以使用的内存为128MB,在较大型的应用项目中,这点内存是不够的,需要调大。Windows下,在文件{tomcat_home}/bin/catalina.bat,Unix下,在文件{tomcat_home}/bin/catalina.sh的前面,增加如下设置:JAVA_OPTS=’-Xms【初始化内存大小】-Xmx【可以使用的最大内存】,需要把这个两个参数值调大。例如:AVA_OPTS=’-Xms256m-Xmx512m’,表示初始化内存为256MB,可以使用的最大内存为512MB。

    • 另外需要考虑的是Java提供的垃圾回收机制。虚拟机的堆大小决定了虚拟机花费在收集垃圾上的时间和频度。收集垃圾可以接受的速度与应用有关,应该通过分析实际的垃圾收集的时间和频率来调整。如果堆的大小很大,那么完全垃圾收集就会很慢,但是频度会降低。如果你把堆的大小和内存的需要一致,完全收集就很快,但是会更加频繁。调整堆大小的的目的是最小化垃圾收集的时间,以在特定的时间内最大化处理客户的请求。在基准测试的时候,为保证最好的性能,要把堆的大小设大,保证垃圾收集不在整个基准测试的过程中出现,   如果系统花费很多的时间收集垃圾,请减小堆大小。一次完全的垃圾收集应该不超过3-5秒。如果垃圾收集成为瓶颈,那么需要指定代的大小,检查垃圾收集的详细输出,研究垃圾收集参数对性能的影响。一般说来,你应该使用物理内存的80%作为堆大小。当增加处理器时,记得增加内存,因为分配可以并行进行,而垃圾收集不是并行的。

  2. Tomcat的内部调优

    • 禁止DNS查找

      有时候我们的应用可能要记录客户端的信息,两种方式,一是记录客户端的数字IP地址,另一个是在DNS数据中查找真实的主机名。DNS查找会增加网络通信,以致造成了网络延迟。要消除这个延迟,我们可以禁掉DNS查找。这时我们的应用再调用getRemoteHost( )方法时,它就只会得到数字IP地址。这个配置是在Tomcat的serve.xml文件中,Connector对象的enableLookups属性,如下:

      <!–
      Define a non-SSLCoyote HTTP/1.1 Connector on port 8080
      –>
      <Connector
          className=”org.apache.coyote.tomcat4.CoyoteConnector”
          port=”8080″minProcessors=”5″ maxProcessors=”75″
          enableLookups=”true” redirectPort=”8443″
          acceptCount=”10″ debug=”0″ connectionTimeout=”20000″
          useURIValidationHack=”false”
      />

      在生产系统中,除非应用要得到所有客户端真实的主机名,这个通常是建议禁掉的。实在不行这样的工作我们可以在Tomcat的外面做。在一个流量较小的Servr这种修改的效果可能不是十分明显,但是对于某些站点来说,也许突然之间流量暴增也说不定呢,比如,前段时间的奥运票务网站,哈哈!

    • 调整线程数

      另一个影响性能的是Connector所使用的进程数。Tomcat使用一个线程池来提高请求响应的速度。Java中的一个线程单独同操作系统交互,并且有它自己的本地内存,以及同进程内的其他线程分享部分共享内存。 我们可以通过修改Connector对象的minProcessors和maxProcessors来控制线程数。这个数字也许在刚上线的时候进行了适当的设置,可是当用户数变多的时候我们就要增加配置数了。minProcessors值应该设置的足够大来处理最小负载。当用户变多的时候,Tomcat会分配更多的线程,不超过maxProcessors。上限也一定要设置的适当,以免使server的内存超过JVM的内存限制而挂掉。

    • 加速JSP的编译

      第一次访问JSP的时候,它会被转换成Java servlet源码,然后编译成二进制代码。这个过程中,我们是可以控制所使用的编译器的。默认情况,Tomcat所使用的是和命令行上执行javac时同样的编译器。其实有更快的编译器的,我们可以利用这些来提高JSP的编译速度。

  3. Tomcat服务器的监控

    • Tomcat自带的监控指标servelet

      第一步:在配置文件中增加用户访问的权限。修改conf/tomcat-users.xml文件,在其中加入一行<user username=”用户名” password=”密码” roles=”manager”/>
      第二步:在IE浏览器中输入http://IP地址:端口号/manager/status
      第三步:在弹出的对话框中输入第一步设置的用户名和密码,即可查看到应用服务器的相关性能指标数据。

    • 使用专门的工具进行监控,网上很多在此就不再赘述。

      在tomcat配置文件server.xml中的配置中,和连接数相关的参数有:
      minProcessors:最小空闲连接线程数,用于提高系统处理性能,默认值为10
      maxProcessors:最大连接线程数,即:并发处理的最大请求数,默认值为75
      acceptCount:允许的最大连接数,即等待队列,指定当所有可以使用的处理请求的线程数都被使用时,可以放到处理队列中的请求数,超过这个数的请求将不予处理。应大于等于maxProcessors,默认值为100,
      enableLookups:是否反查域名,取值为:true或false。为了提高处理能力,应设置为false
      connectionTimeout:网络连接超时,单位:毫秒。设置为0表示永不超时,这样设置有隐患的。通常可设置为30000毫秒。
      和最大连接数相关的参数为maxProcessors和acceptCount。如果要加大并发连接数应同时加大这两个参数。
      web server允许的最大连接数还受制于操作系统的内核参数设置,通常Windows是2000个左右,Linux是1000个左右。

    • server.xml配置简介

      下面讲述这个文件中的基本配置信息,更具体的配置信息请参考tomcat的文档:
      server:
               1、port指定一个端口,这个端口负责监听关闭tomcat的请求
               2、shutdown指定向端口发送的命令字符串
      service:1、name指定service的名字
      Connector(表示客户端和service之间的连接):
               1、port指定服务器端要创建的端口号,并在这个断口监听来自客户端的请求
               2、minProcessors服务器启动时创建的处理请求的线程数
               3、maxProcessors最大可以创建的处理请求的线程数
               4、enableLookups如果为true,则可以通过调用request.getRemoteHost()进行DNS查询来得到远程客户端的实际主机名,若为false则不进行DNS查询,而是返回其ip地址
               5、redirectPort指定服务器正在处理http请求时收到了一个SSL传输请求后重定向的端口号
               6、acceptCount指定当所有可以使用的处理请求的线程数都被使用时,可以放到处理队列中的请求数,超过这个数的请求将不予处理
               7、connectionTimeout指定超时的时间数(以毫秒为单位)线程数可以大致上用“同时在线人数*每秒用户操作次数(每秒的连接数)*系统平均操作时间(服务器的处理时间)”来计算。
      Engine(表示指定service中的请求处理机,接收和处理来自Connector的请求):
               1、defaultHost指定缺省的处理请求的主机名,它至少与其中的一个host元素name属性值是一样的。
      Context(表示一个web应用程序):
               1、docBase应用程序的路径或者是WAR文件存放的路径
               2、path表示此web应用程序的url的前缀,这样请求的url为 http://localhost:8080/path/****
               3、reloadable这个属性非常重要,如果为true,则tomcat会自动检测应用程序的/WEB-INF/lib和/WEB-INF/classes目录的变化,自动装载新的应用程序,我们可以在不重起tomcat的情况下改变应用程序
      host(表示一个虚拟主机):
               1、name指定主机名
               2、appBase应用程序基本目录,即存放应用程序的目录
               3、unpackWARs如果为true,则tomcat会自动将WAR文件解压,否则不解压,直接从WAR文件中运行应用程序
      Logger(表示日志,调试和错误信息):
               1、className指定logger使用的类名,此类必须实现org.apache.catalina.Logger接口
               2、prefix指定log文件的前缀
               3、suffix指定log文件的后缀
               4、timestamp如果为true,则log文件名中要加入时间,例:localhost_log.2001-10-04.txt
       Realm(表示存放用户名,密码及role的数据库):
               1、className指定Realm使用的类名,此类必须实现org.apache.catalina.Realm接口
       Valve(功能与Logger差不多,其prefix和suffix属性解释和Logger中的一样):
               1、className指定Valve使用的类名,如用org.apache.catalina.valves.AccessLogValve类可以记录应用程序的访问信息
      directory(指定log文件存放的位置):1、pattern有两个值,common  


© 著作权归作者所有

共有 人打赏支持
完美世界
粉丝 10
博文 151
码字总数 134011
作品 0
西城
高级程序员
【面试虐菜】—— Jboss调优

  吐血整理了以前Jboss以及JVM在生产环境下的调优参数,各种不同的案例,都是来自网友杜撰。整合后,希望对广大使用jboss作为生产应用服务器的朋友有所帮助。 JBOSS参数调优 配置deploy/jb...

青夜之衫
2017/12/04
0
0
WebSphere 中池资源调优 - 线程池、连接池和 ORB

IBM WebSphere Application Server (以下简称 WAS)能支持的应用程序越来越多,而这些应用程序有各自的独特特性、需求和服务。正如任何两个应用程序都不会采用完全相同的方式来使用应用服务...

IBMdW
2011/06/14
6.3K
2
60扩展:tomcat虚拟主机

1、有时候tomcat虚拟主机在在自建目录文件docBase里,重启无法启动的: 注释:Tomcat本身不能直接在计算机上运行,需要依赖于硬件基础之上的操作系统和一个Java虚拟机。Tomcat的内存溢出本质就...

芬野de博客
09/01
0
0
tomcat 高流量调优

java 环境配置:export JAVA_OPTS="-server -Xms8g -Xmx8g -Xss128k -XX:ParallelGCThreads=20-XX:+UseConcMarkSweepGC -XX:+UseParNewGC -XX:SurvivorRatio=8-XX:TargetSurvivorRatio=90 -......

千惊万喜
2016/12/09
26
0
tomcat调优方案

一、操作系统调优 对于操作系统优化来说,是尽可能的增大可使用的内存容量、提高CPU的频率,保证文件系统的读写速率等。经过压力测试验证,在并发连接很多的情况下,CPU的处理能力越强,系统...

蜡笔小小小新
2015/09/07
64
0

没有更多内容

加载失败,请刷新页面

加载更多

DES/3DES(TripleDES)加密、解密测试数据

以下结果经 PHP+openssl及VB.NET验证,ECB模式。 PHP 7.0.10 (cli) (built: Aug 18 2016 09:48:53) ( ZTS ) OpenSSL Library Version: OpenSSL 1.0.1t 3 May 2016 VB.net 2003 ****** DES(S......

SamXIAO
34分钟前
1
2
Java11的新特性

Java语言特性系列 Java5的新特性 Java6的新特性 Java7的新特性 Java8的新特性 Java9的新特性 Java10的新特性 Java11的新特性 Java12的新特性 序 本文主要讲述一下Java11的新特性 版本号 java...

go4it
35分钟前
3
0
Maven常用命令及相关笔记

Maven常用命令 dos指令 4. 编译源代码: mvn compile 6. 运行测试: mvn test 8. 打包: mvn package 9. 在本地Repository中安装jar: mvn install 10. 清除产生的项目: mvn clean 4. 运行项...

颖伙虫
42分钟前
1
0
swagger2.2.2 与 spring cloud feign冲突 导致服务请求报空

swagger2.2.2 与 spring cloud feign冲突 Java代码 Caused by: org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'com.choosefine.web.console.ar......

泉天下
45分钟前
1
0
设计模式之 明确责任 观察者模式 状态模式 责任链模式

观察者模式是任务分发的一种模式。 如果认为我们设计的系统的各个模块(或子系统)的最终目的是完成共同任务,那么这个任务如何分配到多个模块的就是我们遇到的第一个问题。简单设计场合我们...

backbye
50分钟前
2
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部