转载tomcat高并发配置调优

部署的Tomcat在压测时apk下载不了,查看日志发现是未配置导致不支持高并发。文章给出亲测有效的高并发配置,包括线程池和连接器的配置,最大线程数设为5000,经压测并发4000无压力,可实现5000高并发。

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

最近部署的tomcat,里面放了一个apk提供给测试人员测试,而有一天压测的时候,他们一致反馈下载不了,结果查看日志才发现如下错误:

INFO: Maximum number of threads (200) created for connector with address null and port 8091


才惊醒这个tomcat根本知识解压就使用的,配置都没动过,肯定不能支持高并发了。所以这里给出一个高并发的配置,当然百度一下也会发现很多类似的配置文章,其他的就不去管吧,反正这歌配置是本人亲测,特别是压力测试下是没问题的;

    <Executor name="tomcatThreadPool"        # 配置TOMCAT共享线程池,NAME为名称
              namePrefix="HTTP-8088-exec-"    # 线程的名字前缀,用于标记线程名称
              prestartminSpareThreads="true"  # executor启动时,是否开启最小的线程数
              maxThreads="5000"               # 允许的最大线程池里的线程数量,默认是200,大的并发应该设置的高一些,这里设置可以支持到5000并发
              maxQueueSize="100"              # 任务队列上限
              minSpareThreads="50"            # 最小的保持活跃的线程数量,默认是25.这个要根据负载情况自行调整了。太小了就影响反应速度,太大了白白占用资源
              maxIdleTime="10000"             # 超过最小活跃线程数量的线程,如果空闲时间超过这个设置后,会被关别。默认是1分钟。
     />

    <Connector port="8088" protocol="org.apache.coyote.http11.Http11NioProtocol"
       connectionTimeout="5000" redirectPort="443" proxyPort="443" executor="tomcatThreadPool"  # 采用上面的共享线程池
       URIEncoding="UTF-8"/>


这里本人的最大线程数是5000,当然先上压测的时候并发4000是完全没压力的,当时服务器的资源20%都没用到,所以这一个配置完全足够实现5000高并发。

---------------------
作者:Joker-pan
来源:优快云
原文:https://blog.youkuaiyun.com/u011622226/article/details/72510385
版权声明:本文为博主原创文章,转载请附上博文链接!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值