性能调优配置
在Server.xml
中的 Service
标签内,Executor 在 Connector
标签前 加入如下内容
<Executor name="tomcatThreadPool" namePrefix="catalina-exec-"
# maxThreads :最大并发数。Tomcat 使用线程来处理接收的每个请求,这个值表示 Tomcat 可创建的最大的线程数,默认值是 200,建议500~800
maxThreads="2000"
# minSpareThreads:最小空闲线程数,Tomcat 启动时的初始化的线程数,表示即使没有人使用也开这么多空线程等待,默认值是 10。
minSpareThreads="100"
# maxIdleTime 空闲线程存活的时间,单位毫秒,默认60秒
maxIdleTime="60000"
# maxQueueSize 最大的等待队列数,超过则拒绝请求。
maxQueueSize="100"
# prestartminSpareThreads 为 true 时,minSpareThreads才有效果
prestartminSpareThreads="true" />
<Connector port="9090"
# protocol :tomcat8以上使用org.apache.coyote.http11.Http11Nio2Protocol,效率会更高。
protocol="org.apache.coyote.http11.Http11NioProtocol"
# executor:对Executor元素中名称的引用。 如果启用此属性,并且指定的执行程序存在,则连接器将使用该执行程序,所有其他线程属性将被忽略。
executor="tomcatThreadPool"
# maxThreads: 此Connector将创建的请求处理线程的最大数量,因此确定了可以处理的同时请求的最大数量。 如果未指定,则此属性设置为200。如果执行程序与此连接器相关联,则此属性将被忽略,因为连接器将使用执行程序而不是内部线程池执行任务。
maxThreads="2000"
minSpareThreads="100"
maxSpareThreads="1000"
minProcessors="100"
maxProcessors="2000"
# compression:是否启用GZIP压缩 on为启用(文本数据压缩) off为不启用, force 压缩所有数据
compression="on"
# acceptCount:当tomcat起动的线程数达到最大时,接受排队的请求个数,默认值为100。
acceptCount="1000"
# maxConnections:这个值表示最多可以有多少个socket连接到tomcat上。
maxConnections="2000"
# connectionTimeout:Connector接受一个连接后等待的时间(milliseconds),默认值是60000。
connectionTimeout="20000"
# maxHttpHeaderSize:http请求头信息的最大程度,超过此长度的部分不予处理。一般8K。
maxHttpHeaderSize="8192"
# tcpNoDelay:如果设置为true,TCP_NO_DELAY选项将被设置在服务器套接字,而在大多数情况下提高性能。这是默认设置为true。
tcpNoDelay="true"
# compressionMinSize:当超过最小数据大小才进行压缩。
compressionMinSize="2048"
# compressableMimeType:配置想压缩的数据类型。
compressableMineType="text/html,text/xml,text/javascript,text/css,text/plain"
# disableUploadTimeout:这个标志允许servlet容器使用一个不同的,通常长在数据上传连接超时。 如果不指定,这个属性被设置为true,表示禁用该时间超时。
disableUploadTimeout="true"
# URIEncoding:网站一般采用UTF-8作为默认编码。
URIEncoding="utf-8"
# enableLookups:置为false,禁用DNS查询,从而提高性能
enableLookups="false"
# redirectPort:如果此连接器支持非SSL请求,并且接收到一个匹配的<security-constraint>需要SSL传输的请求,则Catalina将自动将请求重定向到此处指定的端口号。
redirectPort="8443" />
# maxPostSize:设置由容器解析的URL参数的最大长度,-1(小于0)为禁用这个属性,默认为2097152(2M) 请注意, FailedRequestFilter 过滤器可以用来拒绝达到了极限值的请求。
# acceptorThreadCount:用于接受连接的线程数量。增加这个值在多CPU的机器上,尽管你永远不会真正需要超过2。 也有很多非维持连接,您可能希望增加这个值。默认值是1。
# processorCache:协议处理器缓存的处理器对象来提高性能。 该设置决定多少这些对象的缓存。-1意味着无限的,默认是200。 如果不使用Servlet 3.0异步处理,默认是使用一样的maxThreads设置。 如果使用Servlet 3.0异步处理,默认是使用大maxThreads和预期的并发请求的最大数量(同步和异步)。
# connectionLinger:秒数在这个连接器将持续使用的套接字时关闭。默认值是 -1,禁用socket 延迟时间。
# server:隐藏Tomcat版本信息,首先隐藏HTTP头中的版本信息。
maxThreads=“X” 表示最多同时处理X个连接
minSpareThreads=“X” 初始化X个连接
maxSpareThreads=“X” 表示如果最多可以有X个线程,一旦超过X个,则会关闭不在需要的线程
acceptCount=“X” 当同时连接的人数达到maxThreads时,还可以排队,队列大小为X.超过X就不处理
maxSpareThreads:最大备用线程数,一旦创建的线程超过这个值,Tomcat 就会关闭不再需要的 socket 线程。
Executor
Executor表示可以在Tomcat中的组件之间共享的线程池。历史上,每个连接器都有一个线程池,但这允许您共享一个线程池,在(主)连接器和其他组件之间共享线程池,当这些组件被配置为支持executor时
Executor必须实现org.apache.catalina.Executor接口
Executor
是 Service
元素的嵌套元素。为了让连接器接收它,Executor元素必须出现在server.xml中的Connector元素之前
共同属性
Executor的所有实现均支持以下属性:
属性 | 描述 |
---|---|
className | 实现的类。 该实现必须实现org.apache.catalina.Executor接口。 此接口确保可以通过其name属性引用该对象并实现该对象的生命周期,以便可以使用容器启动和停止该对象。 className的默认值为org.apache.catalina.core.StandardThreadExecutor |
name | 用于在server.xml中其他位置引用此池的名称。 名称是必需的,并且必须是唯一的。 |
标准实施
默认实现支持以下属性:
属性 | 描述 |
---|---|
threadPriority | (int)执行程序中线程的线程优先级,默认值为5 ( Thread.NORM_PRIORITY常量的值) |
daemon | (布尔值)线程是否应该是守护程序线程,默认值为true |
namePrefix | (字符串)执行程序创建的每个线程的名称前缀。 单个线程的线程名称将为namePrefix+threadNumber |
maxThreads | (int)此池中活动线程的最大数量,默认为200(Tomcat7和8都是) |
minSpareThreads | (int)始终保持活动状态的最小线程数,默认为25 |
maxIdleTime | (int)线程空闲的最大时间,当空闲超过该值时关闭线程(除非活动线程的数目小于或等于minSpareThreads)默认值为60000 (1分钟) |
maxQueueSize | (int)在我们拒绝执行之前可以排队等待执行的可运行任务的最大数量。 默认值为Integer.MAX_VALUE |