tomcat默认最大连接数及相关调整方法


Posted in Servers onMay 06, 2022

一般来说我们都是用tomcat默认的配置做基础的本地开发,测试及生产肯定不用tomcat啦,正式一点的企业肯定换大型容器了,当然不排除还是用tomcat或者它的集群的,言归正传,tomcat的连接数相关配置及修改干货如下:

在tomcat配置文件server.xml中的<Connector  />标签配置中,和连接数相关的参数有下面几个(如果你现在看肯定都没有的):

  • minProcessors------------------最小空闲连接线程数,用于提高系统处理性能,默认值为10
  • maxProcessors-----------------最大连接线程数,即:并发处理的最大请求数,默认值为75
  • acceptCount---------------------允许的最大连接数,应大于等于maxProcessors,默认值为100
  • enableLookups-----------------是否反查域名,取值为:true或false。为了提高处理能力,应设置为false
  • connectionTimeout------------网络连接超时,单位:毫秒。设置为0表示永不超时,这样设置有隐患的。通常可设置为30000毫秒。

P.S.如果你要手动增加这些链接相关参数,那么根据以上参数肯定是找不到的,官方文档提示需要搞另外两个参数才能加大并发连接数,那就是maxProcessors和acceptCount。

官方原话及翻译:

If more simultaneous requests are received than can be handled by the currently available request processing threads, additional threads will be created up to the configured maximum (the value of the maxThreads attribute).

如果接收到的并发请求比当前可用的请求处理线程所能处理的更多,则将创建额外的线程到配置的最大值(maxThreads 属性)。

If still more simultaneous requests are received, they are stacked up inside the server socket created by the Connector, up to the configured maximum (the value of the acceptCount attribute).

如果接收到更多的并发请求,则它们被堆叠在由连接器创建的服务器套接字内,直到配置的最大值(acceptCount 属性)。

所以需要设置的是maxThreads和acceptCount这两个值,两者的默认值分别是200和100,要调整Tomcat的默认最大连接数,可以增加这两个属性的值,并且使acceptCount大于等于maxThreads:

<Connector port="8080" protocol="HTTP/1.1" 
               connectionTimeout="20000" 
               redirectPort="8443" acceptCount="300" maxThreads="200" />

并发请求数 <= tomcat最大线程数200,可以看到200个请求,响应结果正常
并发数(201) >tomcat最大线程数200.可以看到,因为tomcat最大的线程数为200,201的并发请求量,超出了并发处理的数量200,多出来的1个请求,需要等待某个处理中的请求处理完成
请求数超过最大连接数300,可以看到有大量的没有正常响应的http请求,原因很简单,因为超过了tomcat设置的最大连接数,服务器拒绝了该次请求的连接

增加线程是有成本的,JVM中默认情况下在创建新线程时会分配大小为1M的线程栈,所以更多的线程异味着更多的内存;
更多的线程会带来更多的线程上下文切换成本。

springboot中Tomcat配置建议:
最大工作线程数 ,默认200(4核8G内存,线程数经验值为800,操作系统之间做线程之间切换调度是有开销的,不是越多越好),最大连接数默认是10000,等待长度默认为100,最小工作空闲线程默认10

线程数的经验值为:1核2G内存, 线程数经验值为200,;4核8G内存,线程数经验值为800

到此这篇关于tomcat默认最大连接数及相关调整方法的文章就介绍到这了!


Tags in this post...

Servers 相关文章推荐
Nginx优化服务之网页压缩的实现方法
Mar 31 Servers
关于Nginx中虚拟主机的一些冷门知识小结
Mar 03 Servers
Nginx实现会话保持的两种方式
Mar 18 Servers
详解使用内网穿透工具Ngrok代理本地服务
Mar 31 Servers
nginx容器方式反向代理实战
Apr 18 Servers
tomcat默认最大连接数及相关调整方法
May 06 Servers
tomcat正常启动但网页却无法访问的几种解决方法
May 06 Servers
详解Nginx的超时keeplive_timeout配置步骤
May 25 Servers
nginx设置资源请求目录的方式详解
May 30 Servers
Docker部署Mysql8的实现步骤
Jul 07 Servers
centos环境下nginx高可用集群的搭建指南
Jul 23 Servers
Flink 侧流输出源码示例解析
Sep 23 Servers
如何Tomcat中使用ipv6地址
May 06 #Servers
Tomcat弱口令复现及利用
Vscode中SSH插件如何远程连接Linux
nginx配置限速限流基于内置模块
May 02 #Servers
Nginx配置之禁止指定IP访问
centos7安装mysql5.7经验记录
May 02 #Servers
使用 Docker Compose 构建复杂的多容器App
Apr 30 #Servers
You might like
桌面中心(四)数据显示
2006/10/09 PHP
关于在php.ini中添加extension=php_mysqli.dll指令的说明
2007/06/14 PHP
php实现的css文件背景图片下载器代码
2014/11/11 PHP
php为字符串前后添加指定数量字符的方法
2015/05/04 PHP
php生成gif动画的方法
2015/11/05 PHP
PHP使用标准库spl实现的观察者模式示例
2018/08/04 PHP
php链式操作的实现方式分析
2019/08/12 PHP
javascript简单实现命名空间效果
2014/03/06 Javascript
jquery列表拖动排列(由项目提取相当好用)
2014/06/17 Javascript
基于jQuery实现表单提交验证
2014/11/24 Javascript
基于jquery实现等比缩放图片
2014/12/03 Javascript
javascript动态添加checkbox复选框的方法
2015/12/23 Javascript
easyui datebox 时间限制,datebox开始时间限制结束时间,datebox截止日期比起始日期大的实现代码
2017/01/12 Javascript
Iscrool下拉刷新功能实现方法(推荐)
2017/06/26 Javascript
解决html input验证只能输入数字,不能输入其他的问题
2017/07/21 Javascript
vue中Axios的封装与API接口的管理详解
2018/08/09 Javascript
vue主动刷新页面及列表数据删除后的刷新实例
2018/09/16 Javascript
新手快速上手webpack4打包工具的使用详解
2019/01/28 Javascript
[01:04:09]DOTA2-DPC中国联赛 正赛 iG vs VG BO3 第二场 2月2日
2021/03/11 DOTA
python数据结构之图的实现方法
2015/07/08 Python
浅析Python中的多条件排序实现
2016/06/07 Python
python批量读取txt文件为DataFrame的方法
2018/04/03 Python
详解PyTorch批训练及优化器比较
2018/04/28 Python
Python实现打印实心和空心菱形
2019/11/23 Python
Pytorch训练过程出现nan的解决方式
2020/01/02 Python
详解Python中pyautogui库的最全使用方法
2020/04/01 Python
详解CSS3选择器的使用方法汇总
2015/11/24 HTML / CSS
英国家庭和商业健身器材购物网站:Fitness Options
2018/07/05 全球购物
协议书样本
2014/04/23 职场文书
应用外语系自荐信
2014/06/26 职场文书
好的促销活动方案
2014/08/21 职场文书
加薪通知
2015/04/25 职场文书
小学生表扬稿范文
2015/05/05 职场文书
2016年社区创先争优活动总结
2016/04/05 职场文书
python scipy 稀疏矩阵的使用说明
2021/05/26 Python
详解Go语言中Get/Post请求测试
2022/06/01 Golang