SpringBoot默認最大連接數(shù)的實踐
Spring Boot 應用的最大連接數(shù)取決于多個因素,包括使用的Web服務器類型、配置以及底層操作系統(tǒng)的限制。下面我將詳細分析不同場景下的默認值及其配置方式。
一、默認連接數(shù)概述
不同內嵌服務器的默認值
服務器類型 | 默認最大連接數(shù) | 相關配置屬性 |
---|---|---|
Tomcat (默認) | 8192 | server.tomcat.max-connections |
Jetty | 8192 | server.jetty.max-connections |
Undertow | 1024 | server.undertow.io-threads |
Netty (WebFlux) | 取決于事件循環(huán)線程數(shù) | server.netty.* 相關配置 |
二、Tomcat 的詳細配置(默認服務器)
1. 關鍵線程參數(shù)
# 默認配置 (在Spring Boot 2.x/3.x中) server.tomcat.threads.max=200 # 最大工作線程數(shù) server.tomcat.threads.min-spare=10 # 最小空閑線程數(shù) server.tomcat.max-connections=8192 # 最大連接隊列長度
2. 工作原理
- 連接隊列:當所有工作線程都忙碌時,新連接進入隊列,最大長度為8192
- 線程池:Tomcat使用線程池處理請求,默認最大200線程
- 拒絕策略:當隊列滿時(8192+200),新的連接會被拒絕
3. 計算公式
理論最大并發(fā) = max-threads
+ accept-count
(默認 = 200 + 8192 = 8392)
三、其他服務器的配置
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ù)(默認CPU核心數(shù)×2) server.undertow.threads.worker=256 # 工作線程數(shù) server.undertow.buffer-size=1024 # 緩沖區(qū)大小
四、配置優(yōu)化建議
1. 生產(chǎn)環(huán)境推薦設置
# Tomcat 生產(chǎn)配置示例 server.tomcat.threads.max=800 server.tomcat.threads.min-spare=100 server.tomcat.max-connections=10000 server.tomcat.accept-count=5000 # 連接超時設置 server.tomcat.connection-timeout=5s
2. 考慮因素
- 硬件資源:CPU核心數(shù)、內存大小
- 請求特性:長連接/短連接、請求處理時間
- 業(yè)務類型:CPU密集型 vs I/O密集型
五、如何驗證當前配置
1. 通過Actuator端點
# 首先啟用actuator management.endpoints.web.exposure.include=*
訪問:http://localhost:8080/actuator/env/server.tomcat.*
2. 通過JMX
啟動應用時添加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)級限制
即使Spring Boot配置允許大量連接,仍需檢查:
1. Linux系統(tǒng)限制
# 查看文件描述符限制 ulimit -n # 臨時提高限制 ulimit -n 65535 # 永久修改 # /etc/security/limits.conf * soft nofile 65535 * hard nofile 65535
2. Windows系統(tǒng)限制
Windows的并發(fā)連接數(shù)限制主要取決于:
- 可用端口范圍(通常約16000個臨時端口)
- 注冊表中的
MaxUserPort
和TcpTimedWaitDelay
設置
七、性能測試建議
使用壓測工具驗證實際吞吐量:
# 使用wrk測試 wrk -t12 -c4000 -d30s http://localhost:8080/api # 使用JMeter jmeter -n -t test_plan.jmx -l result.jtl
監(jiān)控指標:
- 活躍線程數(shù)
- 請求排隊時間
- 錯誤率(特別是連接拒絕)
八、常見問題解決
1. 出現(xiàn)"Connection refused"錯誤
- 檢查
max-connections
和accept-count
是否過小 - 檢查操作系統(tǒng)文件描述符限制
- 檢查線程池是否耗盡(線程數(shù)不足或處理阻塞)
2. 高并發(fā)下性能下降
- 適當增加
max-threads
- 優(yōu)化業(yè)務邏輯減少處理時間
- 考慮使用異步處理(如WebFlux)
3. 內存溢出風險
每連接大約消耗2-4KB內存,10000連接約需40MB內存:
- 監(jiān)控JVM內存使用
- 根據(jù)實際內存調整連接數(shù)上限
九、總結
Spring Boot默認連接處理能力:
- Tomcat/Jetty:最大8392并發(fā)(200線程 + 8192隊列)
- Undertow:默認約1000并發(fā)(更依賴I/O線程配置)
實際生產(chǎn)環(huán)境中,應根據(jù):
- 硬件配置
- 業(yè)務需求
- 性能測試結果
進行針對性調優(yōu),而非簡單依賴默認值。記住:更高的連接數(shù)意味著更多的資源消耗,需要在吞吐量和資源利用率之間找到平衡點。
到此這篇關于SpringBoot默認最大連接數(shù)的實踐的文章就介紹到這了,更多相關SpringBoot默認最大連接數(shù)內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
IDEA?Debug過程中使用Drop?Frame或Reset?Frame實現(xiàn)操作回退的方法
在IDEA中就提供了一個幫助你回退代碼的機會,但這個方法并不是萬能的,好了,下面就來具體說說IDEA?Debug過程中使用Drop?Frame或Reset?Frame實現(xiàn)操作回退的方法,感興趣的朋友一起看看吧2022-04-04