京東面試:SpringBoot同時可以處理多少請求?

磊哥課程 2024-05-25 07:45:02

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 呢?接下來,我們來看一下。

4.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 的依賴即可。

4.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>課後思考

爲什麽 Tomcat 默認的最大連接數爲 8192 呢?Jetty 和 Undertow 同時又能處理多少個請求呢?

本文已收錄到我的面試小站 [www.javacn.site](https://www.javacn.site),其中包含的內容有:Redis、JVM、並發、並發、MySQL、Spring、Spring MVC、Spring Boot、Spring Cloud、MyBatis、設計模式、消息隊列等模塊。

1 阅读:394
评论列表
  • 2024-06-11 13:47

    不考慮實際情況問這種問題純屬扯蛋裝逼,帶寬不考慮了?硬件不考慮了?

磊哥課程

簡介:感謝大家的關注