tomcat并发调优

展开

1.场景还原

 

    近期笔者在线上项目中遇到了tomcat假死的现象,服务器相关配置均属正常,但是app访问速度很慢;于是笔者想出两种解决方案:①nginx+tomcat实现负载均衡;②对tomcat并发调优,此前笔者nginx+tomcat负载均衡调优已经实现,今天就tomcat并发调优作个分享

2.实现方案

 

①编辑tomcat/conf/server.xml

 

将默认配置

 

    <Connector port=”8085″ protocol=”HTTP/1.1″

    connectionTimeout=”20000″

    redirectPort=”8443″ />

 

改为如下优化后的配置

 

    <Connector port=”8085″ protocol=”HTTP/1.1″

    connectionTimeout=”5000″

    redirectPort=”18443″

    maxThreads=”2000″

    minSpareThreads=”100″

    maxSpareThreads=”1000″

    minProcessors=”100″

    maxProcessors=”1000″

    enableLookups=”false”

    compression=”on”

    compressionMinSize=”2048″                                                                                                                                                                                                                                                     compressableMimeType=”text/html,text/xml,text/javascript,text/css,text/plain”                                                                                                                                                                                                 URIEncoding=”utf-8″

    acceptCount=”1000″                                                                                                                                                                                                                                                            disableUploadTimeout=”true”/>

    disableUploadTimeout=”true”/>

 

②参数解释

 

    (1)URIEncoding=UTF-8

    使得tomcat可以解析含有中文名的文件的url

     

    (2)minSpareThreads

    最小备用线程数,tomcat启动时的初始化的线程数,默认10.

     

    (3)maxSpareThreads

    最大备用线程数,tomcat启动时的初始化的线程数

     

    (4)enableLookups

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

    (5)disableUploadTimeout    disableUploadTimeout=”true”

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

     

    (6)connectionTimeout

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

     

    (7)acceptCount

    acceptCount是当线程数达到maxThreads后,后续请求会被放入一个等待队列,这个acceptCount是这个队列的大小,如果这个队列也满了,就直接refuse connection.

    一句话:acceptCount:当处理任务的线程数达到最大时,接受排队的请求个数,默认100

     

    (8)maxThreads

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

     

    (9)maxProcessors

    与下面minProcessors相对应,具体解释看下面。

     

    (10)minProcessors

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

     

    (11)useURIValidationHack

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

     

    (12)compression

    compression :设置是否开启GZip压缩

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

     

    (13)compressionMinSize

    compressionMinSize=”2048″ 启用压缩的输出内容大小,这里面默认为2KB

     

    (14)compressableMimeType

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

原文地址:http://www.cnblogs.com/Lqdream/p/16922882.html

1. 本站所有资源来源于用户上传和网络,如有侵权请邮件联系站长! 2. 分享目的仅供大家学习和交流,请务用于商业用途! 3. 如果你也有好源码或者教程,可以到用户中心发布,分享有积分奖励和额外收入! 4. 本站提供的源码、模板、插件等等其他资源,都不包含技术服务请大家谅解! 5. 如有链接无法下载、失效或广告,请联系管理员处理! 6. 本站资源售价只是赞助,收取费用仅维持本站的日常运营所需! 7. 如遇到加密压缩包,默认解压密码为"gltf",如遇到无法解压的请联系管理员! 8. 因为资源和程序源码均为可复制品,所以不支持任何理由的退款兑现,请斟酌后支付下载 声明:如果标题没有注明"已测试"或者"测试可用"等字样的资源源码均未经过站长测试.特别注意没有标注的源码不保证任何可用性