zoukankan      html  css  js  c++  java
  • tomcat8 性能优化

    一、编辑配置文件:vim /opt/tomcat/conf/server.xml
    打开默认被注释的连接池配置:
    默认值:

    <!--
    <Executor name="tomcatThreadPool" namePrefix="catalina-exec-"
        maxThreads="150" minSpareThreads="4"/>
    -->

    修改为:

    <Executor 
        name="tomcatThreadPool" 
        namePrefix="catalina-exec-"
        maxThreads="800" //最大并发数 
        minSpareThreads="50" //初始化时创建的线程数
        prestartminSpareThreads="true"
        maxQueueSize="300"
    />

    重点参数解释:
    maxThreads:最大并发数,默认设置 200,一般建议在 600 ~ 900,根据硬件设施和业务来判断
    minSpareThreads:最小备用线程数,Tomcat初始化时创建的线程数,默认设置25
    maxSpareThreads:最大备用线程数,tomcat启动时的初始化的线程数,
    prestartminSpareThreads:在Tomcat初始化的时候就初始化 minSpareThreads 的参数值,如果不等于 true,minSpareThreads的值就没啥效果了
    maxQueueSize:最大的等待队列数,超过则拒绝请求


    二、修改默认的链接参数配置:
    默认值:

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

    修改为:

    <Connector 
       executor="tomcatThreadPool"
       port="8080" 
       protocol="org.apache.coyote.http11.Http11Nio2Protocol" 
       connectionTimeout="20000" 
       maxConnections="900" 
       redirectPort="8443" 
       enableLookups="false" 
       acceptCount="700" // 指定当所有可以使用的处理请求的线程数都被使用时,可以放到处理队列中的请求数,超过这个数的请求将不予处理
       maxPostSize="10485760" 
       disableUploadTimeout="true" 
       compression="on" 
       compressionMinSize="2048" 
       acceptorThreadCount="2" 
       maxProcessors="1000"
       minProcessors="5"
       compressableMimeType="text/html,text/xml,text/plain,text/css,text/javascript,application/javascript" 
       URIEncoding="UTF-8"
    />

    重点参数解释:
    (1)、protocol Tomcat 8:设置 nio2 更好:org.apache.coyote.http11.Http11Nio2Protocol(如果这个用不了,就用下面那个)
    protocol,Tomcat 6、7:设置 nio 更好:org.apache.coyote.http11.Http11NioProtocol

    (2)、URIEncoding="UTF-8"
    使得tomcat可以解析含有中文名的文件的url

    (3)、enableLookups:禁用DNS查询
    如果希望调用request.getRemoteHost()进行DNS查询,以返回远程客户的实际主机名,将enableLookups设为true。
    如果希望忽略DNS查询,仅仅返回IP地址,设为false(这样提高了性能), 缺省情况下,DNS查询是使能的。
    一句话:是否反查域名,取值为:true 或 false 。为了提高处理能力,应设置为 false

    (4)、disableUploadTimeout
    disableUploadTimeout="true",类似于Apache中的keeyalive一样,是否需要tomcat容器单独设置上传时间限制,这里是不用,还是使用标准的,不去给上传的附件单独做超时设置。

    (5)connectionTimeout
    connectionTimeout:网络连接超时,单位毫秒。设置为 -1 表示永不超时。

    (6)、acceptCount
    acceptCount是当线程数达到maxThreads后,后续请求会被放入一个等待队列,这个acceptCount是这个队列的大小,如果这个队列也满了,就直接refuse connection.
    一句话:acceptCount:当处理任务的线程数达到最大时,接受排队的请求个数,默认100。

    (7)、maxThreads
    maxThreads:最大线程数,即同时处理的任务个数,默认值为200 , Tomcat使用线程来处理接收的每个请求。这个值表示Tomcat可创建的最大的线程数,即最大并发数。保守推荐:600---900。

    (8)、maxProcessors
    与下面minProcessors相对应,具体解释看下面。

    (9)、minProcessors
    在Java中线程是程序运行时的路径,是在一个程序中与其它控制线程无关的、能够独立运行的代码段。它们共享相同的地址空间。多线程帮助程序员写出CPU最大利用率的高效程序,使空闲时间保持最低,从而接受更多的请求。通常Windows是1000个左右,Linux是2000个左右。

    (10)、useURIValidationHack
    减少它对一些url的不必要的检查从而减省开销,为提供性能可以设置为false

    (11)、compression
    compression :设置是否开启GZip压缩HTTP 压缩可以大大提高浏览网站的速度,它的原理是,在客户端请求网页后,从服务器端将网页文件压缩,再下载到客户端,由客户端的浏览器负责解压缩并浏览。相对于普通的浏览过程HTML,CSS,Javascript , Text ,它可以节省40%左右的流量。更为重要的是,它可以对动态生成的,包括CGI、PHP , JSP , ASP , Servlet,SHTML等输出的网页也能进行压缩,压缩效率惊人。

    (12)、compressionMinSize
    compressionMinSize="2048" 启用压缩的输出内容大小,这里面默认为2KB

    (13)、compressableMimeType
    compressableMimeType:哪些类型需要压缩,默认是text/html,text/xml,text/plain

    (14)、maxPostSize:以 FORM URL 参数方式的 POST 提交方式,限制提交最大的大小,默认是 2097152(2兆),它使用的单位是字节。10485760 为 10M。如果要禁用限制,则可以设置为 -1。

    (15)、acceptorThreadCount:用于接收连接的线程的数量,默认值是1。一般这个指需要改动的时候是因为该服务器是一个多核CPU,如果是多核 CPU 一般配置为 2.

    (16)、超时控制:
    修改conf/web.xml文件配置,设置session-timeout的值(单位:分钟)


    最后不要忘了把8443端口的地方也加上同样的配置,因为如果我们走https协议的话,我们将会用到8443端口这个段的配置。

  • 相关阅读:
    mysql8.0 一次性备份导出/导入恢复所有数据库
    访问服务器共享资源不需要输帐号和密码
    win7 系统 提示用户'sa'登录失败
    Adoquery.disablecontrols和enablecontrols
    DBGridEh 导出数据到EXCEL文件
    Microsoft SQL Server 2005资料库(数据库)卸载方法
    64位操作系统下创建组件失败的解决办法
    U盘中的文件为什么看不见?
    解决错误提示unable to invoke code completion due to errors in source cord.
    浪潮服务器Windows Server系统异常断电导致系统中CentOS7虚拟机系统崩溃无法正常启动grub2故障修复error: relocation 0x48 is not implemented yet
  • 原文地址:https://www.cnblogs.com/linjiqin/p/9053075.html
Copyright © 2011-2022 走看看