tomcat Executor

本文介绍了Tomcat的Executor线程池配置,用于性能调优。关键参数包括maxThreads设定最大处理连接数,minSpareThreads初始化连接数,maxSpareThreads设定最大备用线程数,以及acceptCount定义连接队列大小。Executor允许在Tomcat组件间共享线程池,提高资源利用率。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

性能调优配置

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接口

ExecutorService 元素的嵌套元素。为了让连接器接收它,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
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值