从源码剖析SpringBoot中Tomcat的默认最大连接数

简介: 上篇推文为什么你的websocket只能建立256个连接?推出后,有许多小伙伴问:关键是怎么解决256这个问题。嗯,可能是我的标题起的有点问题,不过如果有认真阅读文章的话,应该会知道,其实256的限制是Chrome浏览器对WebSocket进行的限制。不过,对于一个客户端来说,假如一个窗口建立一个WebSocket连接的话,想要达到256个连接,需要打开256个窗口,这个一般来说很少出现。所以大家并不需要太多的担心这个前端限制。

上篇推文为什么你的websocket只能建立256个连接?推出后,有许多小伙伴问:关键是怎么解决256这个问题。嗯,可能是我的标题起的有点问题,不过如果有认真阅读文章的话,应该会知道,其实256的限制是Chrome浏览器对WebSocket进行的限制。不过,对于一个客户端来说,假如一个窗口建立一个WebSocket连接的话,想要达到256个连接,需要打开256个窗口,这个一般来说很少出现。所以大家并不需要太多的担心这个前端限制。


不过,谈到请求连接数限制的问题,我们倒是可以将注意力转移到后端的配置上来。上篇推文中有提到在后端配置文件有如下配置用于定义tomcat请求连接数的:


server.tomcat.max-connections=10000

我们设置为10000可见已经挺大的了。但是,当请求由前端到达后端时,除了连接数与之有关外,还有一个关键的配置那就是线程数。tomact设置允许的最大线程数,也在很大程度上影响着我们后端能够处理的请求个数。


不知道大家在开发过程中有没有这种感觉,当我们真的用上新的框架或功能的时候,遇到一些属性参数,虽然我们有进行配置,但是,还是会希望了解在框架中对应配置项的默认值是多少。尤其是SpringBoot这类“约定优于配置”原则的框架,更需要我们花时间去学习。


强哥个人觉得能够保有这种追根溯源的精神,对我们技术的提升还是很有帮助的。毕竟只会CV的码农太多了,而对于CV回来的东西,无法做到胸有成竹的话,当遇到问题时,只会让我们手足无措。


所以,既然我们考虑到了性能问题,那么当我们没有配置最大请求连接数和最大线程数时,SpringBoot默认对这两个属性的配置值又是多少呢?今天强哥就带着大家一起从源码的角度来探寻一番。不过由于SpringBoot发展较为迅速,我们先从稍老的版本说起,毕竟很多公司的项目用SpringBoot2以下的还比比皆是。强哥接下来先带大家查看SpringBoot1.5.9.RELEASE版本的源码。之后再会提到新版本的改动。


那么从哪里入手进行源码追溯呢?于其像无头苍蝇一样到百度上胡乱搜索不如我们从现有的内容出发。那现在有什么呢?没错就是server.tomcat.max-connections=10000这个配置了。使用IDEA的小伙伴,直接按住Ctrl键再移动鼠标到该配置,鼠标左键点击后,便会跳转到如下类方法中:


8.jpg


ServerProperties是SpringBoot为我们提供的一个配置类,这里也简单提一下SpringBoot中的属性配置类。即利用@ConfigurationProperties注解,获取到配置文件中的内容,然后映射到我们的类中:


9.png


从上面的代码我们便可以得知,ServerProperties是用于映射配置文件中以server开头的属性。同理可知,既然server找到映射了,那么server.tomcat.max-connections=10000中的tomcat呢?很简单,就是作为成员变量配置在ServerProperties类中啦:


10.png


你没看错,哈哈,居然还有Jetty相关的内容,是不是发现了新大陆一般。


有的小伙伴在看到这段代码时肯定会有所联想:Tomcat tomcat = new Tomcat(),嗯?这个Tomcat难不成就是SpringBoot自带的那个内嵌Tomcat?原来它的实现就在这里??额,秀儿,请你先坐下。


其实,这个Tomcat并不是什么所谓的内嵌Tomcat,而只是ServerProperties的内部类而已。那么对他设置值又有什么用呢?这就是SpringBoot的精妙之处,通过我们配置文件中配置的server.tomcat.max-connections=10000便能够拿用户自定义的属性值去替换框架默认的属性值。


好的,了解了这点之后,顺藤摸瓜,我们便可以猜到,max-connections肯定就是Tomcat这个内部类的内部属性了:


11.png


哈哈,果然没错,可是默认值居然是0!!什么情况?难不成SpringBoot默认最大连接数为0,这不可能啊,那不是什么请求都收不到了。既然默认设置了0,肯定有其他地方对其进行了修改。带着疑问找一下,在Tomcat类中,除了对该属性的get,set方法(我们配置文件中配置的属性即调用的这个方法对该值就行修改)之外,我们可以在Tomcat类中的customizeTomcat()方法中,找到对maxConnection的修改:


12.png


点进该方法看看:


13.jpg


关键在这句代码:


protocol.setMaxConnections(Tomcat.this.maxConnections);


可见,它就是将我们在配置文件中自定义配置的max-connections的值在这里进行真正的赋值使用的。那么可想而知,默认值就是在protocol之中。我们继续往上摸:


14.jpg


哦吼,setMaxConnections中对endpoint又进行了赋值,那下一个目标就是endpoint咯,endpoint是个成员属性:


15.png


那就继续进入AbstractEndpoint,找与maxConnections相关内容:


16.jpg


哈哈哈,终于我们摸到瓜啦,从上面代码可以看出,maxConnections的默认值就是10000。不容易啊,历经九九八十一难终于修得正果。为自己呱唧呱唧!!!


同理,上下再找找,发现maxThreads也是在此类中设置了默认值:


17.jpg


默认值是200哦。


到此,我们便完成了对SpringBoot 1.5.9.RELEASE版本中tomcat默认最大连接数的源码追寻过程。那么,为什么要特地提到版本号呢?当然是因为新版的会有所不同了。强哥也在SpringBoot 2.2.3.BUILD-SNAPSHOT中找了一下,这两个配置值直接就在ServerPropertise中进行定义了:


18.jpg


19.png


同样默认最大线程数还是200。


到了这里,可能大家又会有疑问了,maxConnections最大值10000可以理解,毕竟一个服务同时保持10000个连接确实资源也就消耗的差不多了,可是,maxThreads却只有200,是不是少了点。加入了WebSocket之后,都是长连接,那不就更不够了?


这个问题就留给下一篇推文吧,今天就先到这里了,如果感觉我的推文对你有帮助的话,欢迎关注、点再看支持一波哦~

相关文章
|
8天前
|
数据采集 监控 前端开发
二级公立医院绩效考核系统源码,B/S架构,前后端分别基于Spring Boot和Avue框架
医院绩效管理系统通过与HIS系统的无缝对接,实现数据网络化采集、评价结果透明化管理及奖金分配自动化生成。系统涵盖科室和个人绩效考核、医疗质量考核、数据采集、绩效工资核算、收支核算、工作量统计、单项奖惩等功能,提升绩效评估的全面性、准确性和公正性。技术栈采用B/S架构,前后端分别基于Spring Boot和Avue框架。
|
1月前
|
前端开发 Java
表白墙/留言墙 —— 初级SpringBoot项目,练手项目前后端开发(带完整源码) 全方位全步骤手把手教学
文章通过一个表白墙/留言墙的初级SpringBoot项目实例,详细讲解了如何进行前后端开发,包括定义前后端交互接口、创建SpringBoot项目、编写前端页面、后端代码逻辑及实体类封装的全过程。
60 3
表白墙/留言墙 —— 初级SpringBoot项目,练手项目前后端开发(带完整源码) 全方位全步骤手把手教学
|
1月前
|
前端开发 Java 数据安全/隐私保护
用户登录前后端开发(一个简单完整的小项目)——SpringBoot与session验证(带前后端源码)全方位全流程超详细教程
文章通过一个简单的SpringBoot项目,详细介绍了前后端如何实现用户登录功能,包括前端登录页面的创建、后端登录逻辑的处理、使用session验证用户身份以及获取已登录用户信息的方法。
121 2
用户登录前后端开发(一个简单完整的小项目)——SpringBoot与session验证(带前后端源码)全方位全流程超详细教程
|
3月前
|
监控 网络协议 Java
Tomcat源码解析】整体架构组成及核心组件
Tomcat,原名Catalina,是一款优雅轻盈的Web服务器,自4.x版本起扩展了JSP、EL等功能,超越了单纯的Servlet容器范畴。Servlet是Sun公司为Java编程Web应用制定的规范,Tomcat作为Servlet容器,负责构建Request与Response对象,并执行业务逻辑。
Tomcat源码解析】整体架构组成及核心组件
|
6天前
|
JavaScript Java 项目管理
Java毕设学习 基于SpringBoot + Vue 的医院管理系统 持续给大家寻找Java毕设学习项目(附源码)
基于SpringBoot + Vue的医院管理系统,涵盖医院、患者、挂号、药物、检查、病床、排班管理和数据分析等功能。开发工具为IDEA和HBuilder X,环境需配置jdk8、Node.js14、MySQL8。文末提供源码下载链接。
|
1月前
|
缓存 Java Spring
servlet和SpringBoot两种方式分别获取Cookie和Session方式比较(带源码) —— 图文并茂 两种方式获取Header
文章比较了在Servlet和Spring Boot中获取Cookie、Session和Header的方法,并提供了相应的代码实例,展示了两种方式在实际应用中的异同。
118 3
servlet和SpringBoot两种方式分别获取Cookie和Session方式比较(带源码) —— 图文并茂 两种方式获取Header
|
2月前
|
设计模式 Java 关系型数据库
【Java笔记+踩坑汇总】Java基础+JavaWeb+SSM+SpringBoot+SpringCloud+瑞吉外卖/谷粒商城/学成在线+设计模式+面试题汇总+性能调优/架构设计+源码解析
本文是“Java学习路线”专栏的导航文章,目标是为Java初学者和初中高级工程师提供一套完整的Java学习路线。
349 37
|
2月前
|
JavaScript Java 关系型数据库
毕设项目&课程设计&毕设项目:基于springboot+vue实现的在线考试系统(含教程&源码&数据库数据)
本文介绍了一个基于Spring Boot和Vue.js实现的在线考试系统。随着在线教育的发展,在线考试系统的重要性日益凸显。该系统不仅能提高教学效率,减轻教师负担,还为学生提供了灵活便捷的考试方式。技术栈包括Spring Boot、Vue.js、Element-UI等,支持多种角色登录,具备考试管理、题库管理、成绩查询等功能。系统采用前后端分离架构,具备高性能和扩展性,未来可进一步优化并引入AI技术提升智能化水平。
毕设项目&课程设计&毕设项目:基于springboot+vue实现的在线考试系统(含教程&源码&数据库数据)
|
2月前
|
Java 关系型数据库 MySQL
毕设项目&课程设计&毕设项目:springboot+jsp实现的房屋租租赁系统(含教程&源码&数据库数据)
本文介绍了一款基于Spring Boot和JSP技术的房屋租赁系统,旨在通过自动化和信息化手段提升房屋管理效率,优化租户体验。系统采用JDK 1.8、Maven 3.6、MySQL 8.0、JSP、Layui和Spring Boot 2.0等技术栈,实现了高效的房源管理和便捷的租户服务。通过该系统,房东可以轻松管理房源,租户可以快速找到合适的住所,双方都能享受数字化带来的便利。未来,系统将持续优化升级,提供更多完善的服务。
毕设项目&课程设计&毕设项目:springboot+jsp实现的房屋租租赁系统(含教程&源码&数据库数据)
|
23天前
|
Java 关系型数据库 MySQL
springboot学习五:springboot整合Mybatis 连接 mysql数据库
这篇文章是关于如何使用Spring Boot整合MyBatis来连接MySQL数据库,并进行基本的增删改查操作的教程。
35 0
springboot学习五:springboot整合Mybatis 连接 mysql数据库