京東面試:SpringBoot同時可以處理多少請求?
Spring Boot 作為 Java 開發中必備的框架,它為開發者提供了高效且易用的開發工具,所以和它相關的面試題自然也很重要,咱們今天就來看這道經典的面試題:Spring Boot 同時可以處理多少個請求 ?
準確的來說,Spring Boot 同時可以處理多少個請求,并不取決于 Spring Boot 框架本身,而是取決于其內置的 Web 容器(因為 Web 容器的行為,決定了 Spring Boot 的行為,所以咱們姑且認為兩個問題的回答是一樣的)。
1.Web三大容器
Web 容器目前也是三分天下,市面上最常見的三種 Web 容器分別是:Tomcat、Undertow 和 Jetty,其中 Tomcat 為 Spring Boot 框架默認的 Web 容器。
它們三者的區別如下:
- Tomcat 是 Apache 軟件基金會下的開源項目,是最廣泛使用的 Servlet 容器之一,完全實現了 Java Servlet 和 JavaServer Pages(JSP)規范。它不僅是一個 Servlet 容器,也是一個輕量級的應用服務器,盡管相比其他輕量級服務器,Tomcat 被認為是稍微重一些的。Tomcat 支持眾多的企業級特性,如 SSL、連接池等,適合運行大型的、復雜的企業級應用。它的穩定性和成熟度經過了多年的企業級應用驗證,因此在很多企業中作為首選的 Web 容器。
- Undertow 是 Red Hat(紅帽公司)開發的一個靈活的、高性能的 Web 服務器和反向代理服務器,它是 WildFly 應用服務器的默認 Web 容器。Undertow 設計上注重低內存占用和高并發處理能力,尤其擅長處理大量的短連接場景,比如 RESTful API 服務。Undertow 支持 Servlet 3.1、WebSocket以及非阻塞 IO(NIO),并且是支持 HTTP/2 協議的現代服務器之一。它的設計理念在于提供一個模塊化、可嵌入式的解決方案,易于集成到現有的系統中,同時也適合微服務架構。
- Jetty 是一個開源的、輕量級的 Web 服務器和 Servlet 容器,由 Eclipse 基金會維護。它以其可嵌入式、高度可配置性著稱,常用于需要快速啟動和輕量級部署的場景,比如開發階段、測試環境或輕量級應用。Jetty 也支持 Servlet 規范和 WebSocket,且同樣基于 NIO,使得它在處理大量并發連接時表現出色。Jetty 設計上強調靈活性和可擴展性,易于通過 API 定制以滿足特定需求,因此在云環境、持續集成、DevOps 等領域很受歡迎。
“
總的來說,Tomcat 因其成熟穩定和企業級特性適用于大型應用;Undertow 以高性能和低內存占用見長,特別適合處理高并發短連接場景;而 Jetty 則以輕量、靈活、易于嵌入為特點,適合快速開發和輕量級部署。
2.最大連接數和最大等待數
以 Spring Boot 框架默認的 Web 容器 Tomcat 為例,它能夠同時處理多少個請求,其實是在 Spring Boot 框架中的 spring-configuration-metadata.json 文件中配置著,如下圖所示:
打開此文件,搜索“server.tomcat.max-connections”(Tomcat 最大連接數)會得到以下結果:
也就是說,默認情況下 Tomcat 允許的最大連接數是 8192(=8*1024)個。
那么,此時有人可能會認為,默認情況下 Spring Boot 同時能處理的請求數應該是 8192,如果你也是這樣認為,那你就錯了。為什么呢?
因為,雖然 Tomcat 可以允許最大的連接數是 8192,但是 Tomcat 還有一個最大等待數,也就是說,如果達到了 8192 之后,還有一個等待隊列可以存放請求的連接,所以,Spring Boot 可以同時處理多少個連接,等于 Tomcat 的最大連接數加 Tomcat 的最大等待數。
那么,最大等待數是多少呢?
我們繼續在 spring-configuration-metadata.json 文件中,搜索“server.tomcat.accept-count”(Tomcat 最大等待數),搜索結果如下圖所示:
也就是說,默認情況下,Tomcat 最大等待數為 100 個。
3.同時處理請求數
所以得出結論:默認情況下 Spring Boot 能夠同時處理的請求數=最大連接數(8192)+最大等待數(100),結果為 8292 個。
當然,這兩個值是可以在 Spring Boot 配置文件中修改的,如下配置所示:
server:
tomcat:
max-connections: 2000 # 最大連接數
accept-count: 200 # 最大等待數
4.擴展知識:設置Web容器
Spring Boot 框架如何設置 Web 容器為 Jetty 或 Undertow 呢?接下來,我們來看一下。
(1)設置容器為Jetty
要設置 Spring Boot 框架的 Web 容器為 Jetty,只需要修改 pom.xml 文件即可,如下配置所示:
<dependencies>
<!-- Spring Boot Starter Web 但排除Tomcat -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
<!-- 排除Tomcat -->
<exclusions>
<exclusion>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-tomcat</artifactId>
</exclusion>
</exclusions>
</dependency>
<!-- 添加Jetty起步依賴 -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-jetty</artifactId>
</dependency>
</dependencies>
也就是說,只需要將默認的 tomcat 排除掉,添加 jetty 的依賴即可。
(2)設置容器為Undertow
要設置 Spring Boot 框架的 Web 容器為 Undertow 的思路和上面 Jetty 的實現思路相同,只需要修改 pom.xml 文件即可,如下配置所示:
<dependencies>
<!-- Spring Boot Starter Web 但排除Tomcat -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
<exclusions>
<exclusion>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-tomcat</artifactId>
</exclusion>
</exclusions>
</dependency>
<!-- 添加Undertow起步依賴 -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-undertow</artifactId>
</dependency>
</dependencies>