zoukankan      html  css  js  c++  java
  • tomcat 优化

    大家都听说了在Apache Tomcat6 中支持了Java语言的特性 NIO( New I/O),不管你对NIO的技术是否熟悉,但你肯定能想象的到NIO是一个好东西。的确,使用NIO在服务器端会有更好的性能,加强服务器端对并发处理的 性能。  请注意:很抱歉,在tomcat6在默认的配置选项中是没有把NIO功能打开。所以很多正在使用Tomcat6的朋友们本以为能快活的使用上NIO。

    不信,你可以试试,从Apache Tomcat 站点下载 的Tomct6 压缩包中 conf/server.xml的 配置文件第69 行,内容如下:

        <Connector port="8080" protocol="HTTP/1.1" 
           connectionTimeout="20000" 
            redirectPort="8443" />

    进行测试,可以在控制台的启动信息里看见,默认状态下 没有被打开nio配置,启动时的信息,如下:
    2010-2-1 12:59:40 org.apache.coyote.http11.Http11Protocol init
    信息: Initializing Coyote HTTP/1.1 on http-8080
    2010-2-1 12:59:40 org.apache.catalina.startup.Catalina load

    修改成支持NIO的类型,配置如下 

    <Connector port="8080" protocol="org.apache.coyote.http11.Http11NioProtocol "
                   connectionTimeout="20000"
                   redirectPort="8443" />

    进行测试,被打开nio配置,启动时的信息,如下:
    2010-2-1 13:01:01 org.apache.tomcat.util.net.NioSelectorPool getSharedSelector 
    信息: Using a shared selector for servlet write/read 
    2010-2-1 13:01:01 org.apache.coyote.http11.Http11NioProtocol init 
    信息: Initializing Coyote HTTP/1.1 on http-8080

     

    这样才能让你真正体验到Tomcat6下NIO给你的系统带来的快感。

    2

    tomcat6 1000并发量配置 tomcat6配置优化
    2009-11-23 20:21
      <Executor name="tomcatThreadPool" namePrefix="catalina-exec-"
    maxThreads="500" minSpareThreads="400" />  

    <Connector executor="tomcatThreadPool"  
    port="80" protocol="HTTP/1.1"   
    connectionTimeout="20000" enableLookups="false"  
    redirectPort="8443" URIEncoding="UTF-8" acceptCount="1000" /> 

    修改tomcat/conf/server.xml配置文件为以上。

    修改apache-tomcat-6.0.18/bin/catalina.bat配置文件为以下。
    set JAVA_OPTS=-Xms1024m -Xmx1024m -XX:PermSize=128M -XX:MaxPermSize=256m
    这一句加在
    rem ---------------------------------------------------------------------------

    rem Guess CATALINA_HOME if not defined
    之间的位置,不要加到那些if里面去了,否则不一定会生效.
    如果有疑问.可以用
    echo %JAVA_OPTS%>d:/JAVA_OPTS.log
    来查看是否正确的设置了.

    同时告诉大家如果是安装服务版的Tomcat,或者自己手动注入到window的管理-->服务 里去的话,那用这个方式是不行的,需要修改注册表,网上已经有很多内容说明了.大家自己去查吧. 

    以上配置都是经过loadrun下的反复压力测试得来的。对一般的jsp页面(类似于静态页面了)响应速度已经是非常快了。
    但是对不同的业务逻辑一块,还是需要不同的处理方法才能达到最优。
    服务器配置:
    Intel(R) Xeon(R) CPU 3065 @ 2.33GHz
    3.99GB内存
     
    3
     
    在Tomcat和应用程序进行了压力测试后,如果您对应用程序的性能结果不太满意,就可以采取一些性能调整措施了,当然了前提是应用程序没有问题,我们这 里只讲Tomcat的调整。由于Tomcat的运行依赖于JVM,所以在这里我们把Tomcat的调整可以分为两类来详细描述: 

      外部环境调整 

      调整非Tomcat组件,例如Tomcat运行的操作系统和运行Tomcat的java虚拟机。 

      自身调整 

      修改Tomcat自身的参数,调整Tomcat配置文件中的参数。 

      下面我们将详细讲解外部环境调整的有关内容,Tomcat自身调整的内容将在第2部分中阐述。 

      1.JAVA虚拟机性能优化 

      Tomcat本身不能直接在计算机上运行,需要依赖于硬件基础之上的操作系统和一个java虚拟机。您可以选择自己的需要选择不同的操作系统 和对应的JDK的版本(只要是符合Sun发布的Java规范的),但我们推荐您使用Sun公司发布的JDK。确保您所使用的版本是最新的,因为Sun公司 和其它一些公司一直在为提高性能而对java虚拟机做一些升级改进。一些报告显示JDK1.4在性能上比JDK1.3提高了将近10%到20%。 

      可以给Java虚拟机设置使用的内存,但是如果你的选择不对的话,虚拟机不会补偿。可通过命令行的方式改变虚拟机使用内存的大小。如下表所示有两个参数用来设置虚拟机使用内存的大小。 
    参数 
    描述 

    -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【可以使用的最大内存】' 

      需要把这个两个参数值调大。例如: 

      JAVA_OPTS='-Xms256m -Xmx512m' 

      表示初始化内存为256MB,可以使用的最大内存为512MB。 

      另外需要考虑的是Java提供的垃圾回收机制。虚拟机的堆大小决定了虚拟机花费在收集垃圾上的时间和频度。收集垃圾可以接受的速度与应用有 关,应该通过分析实际的垃圾收集的时间和频率来调整。如果堆的大小很大,那么完全垃圾收集就会很慢,但是频度会降低。如果你把堆的大小和内存的需要一致, 完全收集就很快,但是会更加频繁。调整堆大小的的目的是最小化垃圾收集的时间,以在特定的时间内最大化处理客户的请求。在基准测试的时候,为保证最好的性 能,要把堆的大小设大,保证垃圾收集不在整个基准测试的过程中出现。 

      如果系统花费很多的时间收集垃圾,请减小堆大小。一次完全的垃圾收集应该不超过 3-5 秒。如果垃圾收集成为瓶颈,那么需要指定代的大小,检查垃圾收集的详细输出,研究 垃圾收集参数对性能的影响。一般说来,你应该使用物理内存的 80% 作为堆大小。当增加处理器时,记得增加内存,因为分配可以并行进行,而垃圾收集不是并行的。 

      2.操作系统性能优化 

      这里说的操作系统是指运行web服务器的系统软件,当然,不同的操作系统是为不同的目的而设计的。比如OpenBSD是面向安全的,因此在它 的内核中有许多的限制来防止不同形式的服务攻击(OpenBSD的一句座右铭是“默认是最安全的”)。这些限制或许更多地用来运行活跃的web服务器。 

      而我们常用的Linux操作系统的目标是易用使用,因此它有着更高的限制。使用BSD内核的系统都带有一个名为“Generic”的内核,表 明所有的驱动器都静态地与之相连。这样就使系统易于使用,但是如果你要创建一个自定义的内核来加强其中某些限制,那就需要排除不需要的设备。Linux内 核中的许多驱动都是动态地加载的。但是换而言之,内存现在变得越来越便宜,所以因为加载额外的设备驱动就显得不是很重要的。重要的是要有更多的内存,并且 在服务器上腾出更多的可用内存。 

      小提示:虽然现在内存已经相当的便宜,但还是尽量不要购买便宜的内存。那些有牌子的内存虽然是贵一点,但是从可靠性上来说,性价比会更高一些。 

      如果是在Windows操作系统上使用Tomcat,那么最好选择服务器版本。因为在非服务器版本上,最终用户授权数或者操作系统本身所能承受的用户数、可用的网络连接数或其它方面的一些方面都是有限制的。并且基于安全性的考虑,必须经常给操作系统打上最新的补丁。 

      3.Tomcat与其它web服务器整合使用 

      虽然tomcat也可以作web服务器,但其处理静态html的速度比不上apache,且其作为web服务器的功能远不如apache,因 此我们想把apache和tomcat集成起来,将html与jsp的功能部分进行明确分工,让tomcat只处理jsp部分,其它的由apache, IIS等这些web服务器处理,由此大大节省了tomcat有限的工作“线程”。 

      4.负载均衡 

      在负载均衡的思路下,多台服务器为对称方式,每台服务器都具有同等的地位,可以单独对外提供服务而无须其他服务器的辅助。通过负载分担技术,将外部发送来的请求按一定规则分配到对称结构中的某一台服务器上,而接收到请求的服务器都独立回应客户机的请求。 

      提供服务的一组服务器组成了一个应用服务器集群(cluster),并对外提供一个统一的地址。当一个服务请求被发至该集群时,根据一定规则选择一台服务器,并将服务转定向给该服务器承担,即将负载进行均衡分摊。 

      通过应用负载均衡技术,使应用服务超过了一台服务器只能为有限用户提供服务的限制,可以利用多台服务器同时为大量用户提供服务。当某台服务器 出现故障时,负载均衡服务器会自动进行检测并停止将服务请求分发至该服务器,而由其他工作正常的服务器继续提供服务,从而保证了服务的可靠性。 

      负载均衡实现的方式大概有四种:第一是通过DNS,但只能实现简单的轮流分配,不能处理故障,第二如果是基于MS IIS, Windows 2003 server本身就带了负载均衡服务,第三是硬件方式,通过交换机的功能或专门的负载均衡设备可以实现,第四种是软件方式,通过一台负载均衡服务器进行, 上面安装软件。使用Apache Httpd Server做负载平衡器,Tomcat集群节点使用Tomcat就可以做到以上第四种方式。这种方式比较灵活,成本相对也较低。另外一个很大的优点就是 可以根据应用的情况和服务器的情况采取一些策略。 

    大家都知道,JAVA程序启动时都会JVM都会分配一个初始内存和最大内存给这个应用程序。这个初始内存和最大内存在一定程度都会影响程序的性能。比如说在应用程序用到最大内存的时候,JVM是要先去做垃圾回收的动作,释放被占用的一些内存。 
            所以想调整Tomcat的启动时初始内存和最大内存就需要向JVM声明,一般的JAVA程序在运行都可以通过中-Xms -Xmx来调整应用程序的初始内存和最大内存: 
            如:java -Xms64m  -Xmx128m  a.jar. 
    tomcat的启动程序是包装过的,不能直接使用java -X..... tomcat.*来改变内存的设置。在Tomcat在改变这个设置 
    有两种方法: 
    1.    就需要在环境变量中加上TOMCAT_OPTS, CATALINA_OPTS两个属性, 
            如 SET  CATALINA_OPTS= -Xms64m -Xmx512m; 
            ms是最小的,mx是最大,64m, 512m分别是指内存的容量. 
    2.    修改Catalina.bat文件 
           在166行“rem Execute Java with the applicable properties ”以下每行 
    %_EXECJAVA% %JAVA_OPTS% %CATALINA_OPTS% %DEBUG_OPTS% -Djava.endorsed.dirs ="%JAVA_ENDORSED_DIRS%" -classpath "%CLASSPATH%" -Dcatalina.base="%CATALINA_BASE %" -Dcatalina.home="%CATALINA_HOME%" -Djava.io.tmpdir="%CATALINA_TMPDIR%"  %MAINCLASS% %CMD_LINE_ARGS% %ACTION% 中的%CATALINA_OPTS% 替换成-Xms64m - Xmx512m 

    Tomcat性能优化 

    1.停用DNS查询 
    server.xml里 
    <Connector 
    port="8887" maxThreads="150" minSpareThreads="25" maxSpareThreads="75" 
    enableLookups="false" redirectPort="8443" acceptCount="100" 
    debug="0" connectionTimeout="20000" 
    disableUploadTimeout="true" /> 

    加上enableLookups="false";这样就不使用DNS查询,也不会有延迟了 
    除非需要所有连接到服务器的HTTP客户端的完整主机名称 

    注:Connector的enableLookups性属的意义是:调用request.getRemoteHost()是否会通过DNS查询来取得远处客户端的真正主机名称。true表示会查询,false表示以字符串格式传回客户端的IP地址。默认值是:true 

    2,调整线程的数目 
    Tomcat使用线程池以便对传入的请求提供快速的响应。 
    通过更改Connector的minProcessors与maxProcessors的值,可以控制所分配的线程数目 
    将这两个参数设为最佳值的最好方式是对各个参数尝试许多不同的设定值,然后以仿真的网络流量进行测试,同时并观察响应时间与内存的使用量。每一种 机器、操作系统与JVM的组合都可能有不同的表现,而且并非所有人的网站流量都会相同,所以没有现成的规则来决定最小与最大的线程数 

    3.加快jsp的编译速度,预先编译jsp 

    4.容量规划:经验式的容量规划,企业容量规划 

    经验式的容量规划与企业容量规划最大的差异就是深度。经验式容量规划使用经验法则,因此比较像是经验预测,而企业容量规划则是深度地研究需求与性能,其目标是尽可能产生最精确的数字
  • 相关阅读:
    SoC FPGA开发板的FPGA配置数据下载和固化
    字体解码
    ProxyApi-大数据采集用的IP代理池
    mongodb-to-mongodb
    mongodb分片
    kubernetes部署kube-scheduler服务
    kubernetes部署kube-controller-manager服务
    kubernetes部署 kube-apiserver服务
    kubernetes部署haproxy、keepalived为kube-apiserver做集群
    kubernetes部署Docker私有仓库Registry
  • 原文地址:https://www.cnblogs.com/LLLONG/p/3169301.html
Copyright © 2011-2022 走看看