SpringBoot默認(rèn)最大連接數(shù)的實(shí)踐
Spring Boot 應(yīng)用的最大連接數(shù)取決于多個(gè)因素,包括使用的Web服務(wù)器類型、配置以及底層操作系統(tǒng)的限制。下面我將詳細(xì)分析不同場(chǎng)景下的默認(rèn)值及其配置方式。
一、默認(rèn)連接數(shù)概述
不同內(nèi)嵌服務(wù)器的默認(rèn)值
服務(wù)器類型 | 默認(rèn)最大連接數(shù) | 相關(guān)配置屬性 |
---|---|---|
Tomcat (默認(rèn)) | 8192 | server.tomcat.max-connections |
Jetty | 8192 | server.jetty.max-connections |
Undertow | 1024 | server.undertow.io-threads |
Netty (WebFlux) | 取決于事件循環(huán)線程數(shù) | server.netty.* 相關(guān)配置 |
二、Tomcat 的詳細(xì)配置(默認(rèn)服務(wù)器)
1. 關(guān)鍵線程參數(shù)
# 默認(rèn)配置 (在Spring Boot 2.x/3.x中) server.tomcat.threads.max=200 # 最大工作線程數(shù) server.tomcat.threads.min-spare=10 # 最小空閑線程數(shù) server.tomcat.max-connections=8192 # 最大連接隊(duì)列長(zhǎng)度
2. 工作原理
- 連接隊(duì)列:當(dāng)所有工作線程都忙碌時(shí),新連接進(jìn)入隊(duì)列,最大長(zhǎng)度為8192
- 線程池:Tomcat使用線程池處理請(qǐng)求,默認(rèn)最大200線程
- 拒絕策略:當(dāng)隊(duì)列滿時(shí)(8192+200),新的連接會(huì)被拒絕
3. 計(jì)算公式
理論最大并發(fā) = max-threads
+ accept-count
(默認(rèn) = 200 + 8192 = 8392)
三、其他服務(wù)器的配置
1. Jetty 配置
server.jetty.threads.max=200 server.jetty.threads.min=8 server.jetty.threads.idle-timeout=60000ms server.jetty.max-connections=8192
2. Undertow 配置
server.undertow.threads.io=8 # I/O線程數(shù)(默認(rèn)CPU核心數(shù)×2) server.undertow.threads.worker=256 # 工作線程數(shù) server.undertow.buffer-size=1024 # 緩沖區(qū)大小
四、配置優(yōu)化建議
1. 生產(chǎn)環(huán)境推薦設(shè)置
# Tomcat 生產(chǎn)配置示例 server.tomcat.threads.max=800 server.tomcat.threads.min-spare=100 server.tomcat.max-connections=10000 server.tomcat.accept-count=5000 # 連接超時(shí)設(shè)置 server.tomcat.connection-timeout=5s
2. 考慮因素
- 硬件資源:CPU核心數(shù)、內(nèi)存大小
- 請(qǐng)求特性:長(zhǎng)連接/短連接、請(qǐng)求處理時(shí)間
- 業(yè)務(wù)類型:CPU密集型 vs I/O密集型
五、如何驗(yàn)證當(dāng)前配置
1. 通過(guò)Actuator端點(diǎn)
# 首先啟用actuator management.endpoints.web.exposure.include=*
訪問(wèn):http://localhost:8080/actuator/env/server.tomcat.*
2. 通過(guò)JMX
啟動(dòng)應(yīng)用時(shí)添加JVM參數(shù):
-Dspring.jmx.enabled=true -Djava.rmi.server.hostname=localhost -Dcom.sun.management.jmxremote.port=1099 -Dcom.sun.management.jmxremote.ssl=false -Dcom.sun.management.jmxremote.authenticate=false
使用JConsole或VisualVM連接查看
六、操作系統(tǒng)級(jí)限制
即使Spring Boot配置允許大量連接,仍需檢查:
1. Linux系統(tǒng)限制
# 查看文件描述符限制 ulimit -n # 臨時(shí)提高限制 ulimit -n 65535 # 永久修改 # /etc/security/limits.conf * soft nofile 65535 * hard nofile 65535
2. Windows系統(tǒng)限制
Windows的并發(fā)連接數(shù)限制主要取決于:
- 可用端口范圍(通常約16000個(gè)臨時(shí)端口)
- 注冊(cè)表中的
MaxUserPort
和TcpTimedWaitDelay
設(shè)置
七、性能測(cè)試建議
使用壓測(cè)工具驗(yàn)證實(shí)際吞吐量:
# 使用wrk測(cè)試 wrk -t12 -c4000 -d30s http://localhost:8080/api # 使用JMeter jmeter -n -t test_plan.jmx -l result.jtl
監(jiān)控指標(biāo):
- 活躍線程數(shù)
- 請(qǐng)求排隊(duì)時(shí)間
- 錯(cuò)誤率(特別是連接拒絕)
八、常見(jiàn)問(wèn)題解決
1. 出現(xiàn)"Connection refused"錯(cuò)誤
- 檢查
max-connections
和accept-count
是否過(guò)小 - 檢查操作系統(tǒng)文件描述符限制
- 檢查線程池是否耗盡(線程數(shù)不足或處理阻塞)
2. 高并發(fā)下性能下降
- 適當(dāng)增加
max-threads
- 優(yōu)化業(yè)務(wù)邏輯減少處理時(shí)間
- 考慮使用異步處理(如WebFlux)
3. 內(nèi)存溢出風(fēng)險(xiǎn)
每連接大約消耗2-4KB內(nèi)存,10000連接約需40MB內(nèi)存:
- 監(jiān)控JVM內(nèi)存使用
- 根據(jù)實(shí)際內(nèi)存調(diào)整連接數(shù)上限
九、總結(jié)
Spring Boot默認(rèn)連接處理能力:
- Tomcat/Jetty:最大8392并發(fā)(200線程 + 8192隊(duì)列)
- Undertow:默認(rèn)約1000并發(fā)(更依賴I/O線程配置)
實(shí)際生產(chǎn)環(huán)境中,應(yīng)根據(jù):
- 硬件配置
- 業(yè)務(wù)需求
- 性能測(cè)試結(jié)果
進(jìn)行針對(duì)性調(diào)優(yōu),而非簡(jiǎn)單依賴默認(rèn)值。記?。焊叩倪B接數(shù)意味著更多的資源消耗,需要在吞吐量和資源利用率之間找到平衡點(diǎn)。
到此這篇關(guān)于SpringBoot默認(rèn)最大連接數(shù)的實(shí)踐的文章就介紹到這了,更多相關(guān)SpringBoot默認(rèn)最大連接數(shù)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
java中sleep方法和wait方法的五個(gè)區(qū)別
這篇文章主要介紹了java中sleep方法和wait方法的五個(gè)區(qū)別,sleep?方法和?wait?方法都是用來(lái)將線程進(jìn)入休眠狀態(tài),但是又有一些區(qū)別,下面我們就一起來(lái)看看吧2022-05-0510個(gè)Java程序員熟悉的面向?qū)ο笤O(shè)計(jì)原則
這篇文章主要為大家詳細(xì)介紹了Java程序員應(yīng)當(dāng)知道的10個(gè)面向?qū)ο笤O(shè)計(jì)原則,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-03-03利用Java實(shí)現(xiàn)mTLS調(diào)用
這篇文章主要介紹使用 Java作為客戶端 與受 mTLS 保護(hù)的服務(wù)交互。為了對(duì)我們的 Java 客戶端進(jìn)行 ssl 配置,我們需要先設(shè)置一個(gè) SSLContext。這簡(jiǎn)化了事情,因?yàn)?SSLContext 可用于各種 http 客戶端,接下來(lái)我們一起進(jìn)入下面文章了解具體內(nèi)容,需要的朋友可以參考一下2021-11-11mybatis使用mapper代理開(kāi)發(fā)方式
使用MyBatis代理開(kāi)發(fā)模式時(shí),需要注意定義與映射配置文件同名的接口類,確保namespace屬性與接口路徑一致,接口方法名和映射文件中的id名稱相同,返回類型保持一致,在mybatis-config.xml中配置映射文件路徑,保證結(jié)構(gòu)一致,可通過(guò)注解@Param傳遞多個(gè)參數(shù)2024-10-10IDEA?Debug過(guò)程中使用Drop?Frame或Reset?Frame實(shí)現(xiàn)操作回退的方法
在IDEA中就提供了一個(gè)幫助你回退代碼的機(jī)會(huì),但這個(gè)方法并不是萬(wàn)能的,好了,下面就來(lái)具體說(shuō)說(shuō)IDEA?Debug過(guò)程中使用Drop?Frame或Reset?Frame實(shí)現(xiàn)操作回退的方法,感興趣的朋友一起看看吧2022-04-04springboot-assembly自定義打包全過(guò)程
這篇文章主要介紹了springboot-assembly自定義打包全過(guò)程,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-06-06