tomcat高并发优化的参数优化并查看tomcat线程数

在Tomcat配置文件conf下面 server.xml 中的配置中和链接数相关的参数有:html

minProcessors:最小空闲链接线程数,用于提升系统处理性能,默认值为10java

maxProcessors:最大链接线程数,即:并发处理的最大请求数,默认值为75apache

acceptCount:容许的最大链接数,应大于等于maxProcessors,默认值为100tomcat

enableLookups:是否反查域名,取值为:true或false。为了提升处理能力,应设置为false网络

connectionTimeout:网络链接超时,单位:毫秒。设置为0表示永不超时,这样设置有隐患的。一般可设置为30000毫秒。并发

参数修改负载均衡

默认的tomcat 参数:异步

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

修改: socket

<Connector port=“8080" protocol="org.apache.coyote.http11.Http11NioProtocol"
maxThreads="600"
minSpareThreads="100"
maxSpareThreads="500"
acceptCount="700"
connectionTimeout="20000"
redirectPort="8443" />

参数说明:性能

protocol="org.apache.coyote.http11.Http11NioProtocol" 使用java的异步io护理技术,no blocking IO

maxThreads=“600" 表示最多同时处理600个链接最大线程数

minSpareThreads=“100" 表示即便没有人使用也开这么多空线程等待,初始化时建立的线程数

maxSpareThreads=“500" 表示若是最多能够空500个线程,例如某时刻有505人访问,以后没有人访问了,则tomcat不会保留505个空线程,而是关闭5个空的。 一旦建立的线程超过这个值,Tomcat就会关闭再也不须要的socket线程。

acceptCount="700" 指定当全部能够使用的处理请求的线程数都被使用时,能够放处处理队列中的请求数,超过这个数的请求将不予处理

 

ajp协议优化

若是使用apache和tomcat作集群的负载均衡,而且使用ajp协议作apache和tomcat的协议转发,须要优化ajp connector。<Connector port="8009" protocol="AJP/1.3" maxThreads="600" minSpareThreads="100" maxSpareThreads="500" acceptCount="700" connectionTimeout="20000" redirectPort="8443" />

 

查看tomcat线程数:

获取tomcat进程pid 
ps -ef|grep tomcat

统计该tomcat进程内的线程个数 ps -Lf 29295 |wc -l

相关文章
相关标签/搜索