溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

Tomcat是如何處理SpringBoot應(yīng)用的

發(fā)布時間:2021-09-29 17:46:02 來源:億速云 閱讀:153 作者:柒染 欄目:大數(shù)據(jù)

這篇文章給大家介紹Tomcat是如何處理SpringBoot應(yīng)用的,內(nèi)容非常詳細,感興趣的小伙伴們可以參考借鑒,希望對大家能有所幫助。

近一兩年, SpringBoot 由于其減少了大量原本繁瑣的 Spring 配置,以及基于 Boot 的 SpringCloud 的推廣,越來越多的應(yīng)用開始使用 SpringBoot進行開發(fā)。

而 SpringBoot 以標準Java 應(yīng)用的形式,來啟動了一個 Web 服務(wù),而將容器的存在,隱藏在一個配置文件中,使用起來很方便。而 Tomcat 就是 Spring Boot 內(nèi)置的容器之一。

這次我們來看在 SpringBoot 中, Tomcat 中怎樣被集成進來提供服務(wù)的。

 在 Spring Boot 中,實現(xiàn)也基本類似。 區(qū)別在于配置信息大部分是默認的,另外一些用戶特定設(shè)置的,通過在 application.properties 之類的 Boot 配置文件里,讀出來解析并設(shè)置到 Tomcat 的各個組件上。

另外一個區(qū)別是, Spring Boot 使用的是 Embedded Tomcat 。這個我們在前面的文章里也曾簡單介紹過 (Embedded Tomcat,朋友,要不要試試)

 當然,上面這兩點,是整個 Boot 項目中使用到 Tomcat 的基本原理,但具體對于 Embedded Tomcat 的使用,Boot 里和 Maven 插件的使用還是有一些區(qū)別的。

這是 Boot 使用的三個embedded 容器,默認啟動的是 Tomcat。

要分析這個問題,該從哪看起呢?

Boot 在啟動的時候,很清楚的告訴我們這樣一條信息

s.b.c.e.t.TomcatEmbeddedServletContainer : Tomcat initialized with port 

我們看到的這一條是logback輸出的信息。前面是縮略形式寫的包名,最主要的是這個Container,跳轉(zhuǎn)到類里看一眼。

可以匹配到這一行 log 的, 是 container 的init 方法

Tomcat是如何處理SpringBoot應(yīng)用的

前面一些細節(jié)類的內(nèi)容先不過多關(guān)注,進入眼里的, 一定是這個

this.tomcat.start();

這里這個 tomcat ,就是 Embedded Tomcat類的實例。

這里 start 的操作,是將 容器啟動起來

Tomcat是如何處理SpringBoot應(yīng)用的

方法里的 getServer, getConnector 這些, 熟悉 Tomcat 的朋友都了解,Tomcat 內(nèi)部有以下幾個主要的組件:

  • Egine

  • Host

  • Context

  • Wrapper

  • Connector

前四個是容器從上到下的組件,是一個包含的關(guān)系。而光有這些還不足以讓我們訪問到部署的應(yīng)用,此時容器連接外界的組件 Connector 就顯的必不可少了。

而且,真正到了start 這一步的時候,容器的組件配置都已經(jīng)完成了,只是要啟動以提供服務(wù)。 配置的這些讀取,都是在 initial 階段之前,已經(jīng)完成。

下圖是初始化階段讀取配置時的一些代碼, 沒有特別的地方,設(shè)置 BaseDir, 解析配置設(shè)置各個組件。

Tomcat是如何處理SpringBoot應(yīng)用的

此外,在Spring Boot 應(yīng)用啟動時,會有這樣幾條日志輸出。

Tomcat是如何處理SpringBoot應(yīng)用的

我們知道,Spring MVC 是通過 DispatcherServlet 來分發(fā)處理請求,在 Spring Boot 出現(xiàn)之前,都是需要在web.xml里配置,來實現(xiàn)請求的攔截。

而在Servlet 3.0 之后,規(guī)則中新增了Dynamic Servlet、Dynamic Filter這些概念, 可以在運行時動態(tài)注冊組件到 Context 中。

Tomcat是如何處理SpringBoot應(yīng)用的

所以我們觀察到的 Context 僅僅是一個空的應(yīng)用,然后再通過動態(tài)添加Servlet、 Filter 等內(nèi)容進去。

除了以 Jar 的形式直接執(zhí)行 Main 方法外, Spring Boot 還支持將 Boot 應(yīng)用打包成 War 文件,部署到標準和容器中,不使用 Embedded 容器。

相比執(zhí)行 Main 方法來啟動 Spring Boot  應(yīng)用,以 Web 應(yīng)用提供時, Boot 的能力是如何提供的呢?

來看下面這張圖,Jar文件的META-INF中services中包含一個SCI的聲明。

Tomcat是如何處理SpringBoot應(yīng)用的

這就是Spring Boot 在標準Web容器中能生效的秘密。 

SCI是做什么的呢?

容器啟動時會依次處理每個 ServletContainerInitializer 的HandlesTypes注解,然后分別調(diào)用所有ServletContainerInitializer對象的onStartup方法,并將處理HandlesTypes注解得到的類數(shù)組,傳遞給ServletContainerInitializer的onStartup方法。

在configure階段,我們將 Boot 打包成 war 時提供的Initalizer,并將其 run 起來。

此時處理 dispatcherServlet 這些,和 以Main方法啟動執(zhí)行沒什么區(qū)別。

所以,當我們看到 Boot 應(yīng)用能夠以如此少的配置便利的作為 Web 應(yīng)用執(zhí)行時,要清楚的認識到,背后的 Embedded 容器 還是做了不少工作,同時也是和各種新的 J2EE規(guī)范有關(guān)。 而最重要的是,無論怎么變化,本質(zhì)上還是那樣,做為一個標準的 Context 在使用,區(qū)別只在于是通過解析靜態(tài)文件進行配置,還是通過動態(tài)添加進行配置。

關(guān)于Tomcat是如何處理SpringBoot應(yīng)用的就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI