當(dāng)前位置:首頁 > 公眾號精選 > 架構(gòu)師社區(qū)
[導(dǎo)讀]Tomcat的前身為Catalina,而Catalina又是一個輕量級的Servlet容器。在美國,catalina是一個很美的小島。所以Tomcat作者的寓意可能是想把Tomcat設(shè)計成一個優(yōu)雅美麗且輕量級的web服務(wù)器。Tomcat從4.x版本開始除了作為支持Servlet的容器外,額外加入了很多的功能,比如:jsp、el、naming等等,所以說Tomcat不僅僅是Catalina。

前言

Tomcat的前身為Catalina,而Catalina又是一個輕量級的Servlet容器。在美國,catalina是一個很美的小島。所以Tomcat作者的寓意可能是想把Tomcat設(shè)計成一個優(yōu)雅美麗且輕量級的web服務(wù)器。Tomcat從4.x版本開始除了作為支持Servlet的容器外,額外加入了很多的功能,比如:jsp、el、naming等等,所以說Tomcat不僅僅是Catalina。

既然Tomcat首先是一個Servlet容器,我們應(yīng)該更多的關(guān)心Servlet。

那么,什么是Servlet呢?

在互聯(lián)網(wǎng)興起之初,當(dāng)時的Sun公司(后面被Oracle收購)已然看到了這次機(jī)遇,于是設(shè)計出了Applet來對Web應(yīng)用的支持。不過事實卻并不是預(yù)期那么得好,Sun悲催地發(fā)現(xiàn)Applet并沒有給業(yè)界帶來多大的影響。經(jīng)過反思,Sun就想既然機(jī)遇出現(xiàn)了,市場前景也非常不錯,總不能白白放棄了呀,怎么辦呢?于是又投入精力去搞一套規(guī)范出來,這時Servlet誕生了!

所謂Servlet,其實就是Sun為了讓Java能實現(xiàn)動態(tài)可交互的網(wǎng)頁,從而進(jìn)入Web編程領(lǐng)域而制定的一套標(biāo)準(zhǔn)!

一個Servlet主要做下面三件事情:

  1. 創(chuàng)建并填充Request對象,包括:URI、參數(shù)、method、請求頭信息、請求體信息等
  2. 創(chuàng)建Response對象
  3. 執(zhí)行業(yè)務(wù)邏輯,將結(jié)果通過Response的輸出流輸出到客戶端Servlet沒有main方法,所以,如果要執(zhí)行,則需要在一個容器里面才能執(zhí)行,這個容器就是為了支持Servlet的功能而存在,Tomcat其實就是一個Servlet容器的實現(xiàn)。

整體架構(gòu)圖

整體的架構(gòu)圖如下:

Tomcat源碼分析:一文帶你整體把握架構(gòu)及組件

從上圖我們看出,最核心的兩個組件--連接器(Connector)和容器(Container)起到心臟的作用,他們至關(guān)重要!他們的作用如下:

  1. Connector用于處理連接相關(guān)的事情,并提供Socket與Request和Response相關(guān)的轉(zhuǎn)化;
  2. Container用于封裝和管理Servlet,以及具體處理Request請求;

一個Tomcat中只有一個Server,一個Server可以包含多個Service,一個Service只有一個Container,但是可以有多個Connectors,這是因為一個服務(wù)可以有多個連接,如同時提供Http和Https鏈接,也可以提供向相同協(xié)議不同端口的連接,示意圖如下(Engine、Host、Context下邊會說到):

Tomcat源碼分析:一文帶你整體把握架構(gòu)及組件

多個 Connector 和一個 Container 就形成了一個 Service,有了 Service 就可以對外提供服務(wù)了,但是 Service 還要一個生存的環(huán)境,必須要有人能夠給她生命、掌握其生死大權(quán),那就非 Server 莫屬了!所以整個 Tomcat 的生命周期由 Server 控制。

另外,上述的包含關(guān)系或者說是父子關(guān)系,都可以在tomcat的conf目錄下的server.xml配置文件中看出

Tomcat源碼分析:一文帶你整體把握架構(gòu)及組件

上邊的配置文件,還可以通過下邊的一張結(jié)構(gòu)圖更清楚的理解:

Tomcat源碼分析:一文帶你整體把握架構(gòu)及組件

下面我們逐一來分析各個組件的功能:

  1. Server表示服務(wù)器,提供了一種優(yōu)雅的方式來啟動和停止整個系統(tǒng),不必單獨(dú)啟停連接器和容器
  2. Service表示服務(wù),Server可以運(yùn)行多個服務(wù)。比如一個Tomcat里面可運(yùn)行訂單服務(wù)、支付服務(wù)、用戶服務(wù)等等
  3. 每個Service可包含多個Connector和一個Container。因為每個服務(wù)允許同時支持多種協(xié)議,但是每種協(xié)議最終執(zhí)行的Servlet卻是相同的
  4. Connector表示連接器,比如一個服務(wù)可以同時支持AJP協(xié)議、Http協(xié)議和Https協(xié)議,每種協(xié)議可使用一種連接器來支持
  5. Container表示容器,可以看做Servlet容器
  • Engine -- 引擎
  • Host -- 主機(jī)
  • Context -- 上下文
  • Wrapper -- 包裝器
  1. Service服務(wù)之下還有各種支撐組件,下面簡單羅列一下這些組件
  • Manager -- 管理器,用于管理會話Session
  • Logger -- 日志器,用于管理日志
  • Loader -- 加載器,和類加載有關(guān),只會開放給Context所使用
  • Pipeline -- 管道組件,配合Valve實現(xiàn)過濾器功能
  • Valve -- 閥門組件,配合Pipeline實現(xiàn)過濾器功能
  • Realm -- 認(rèn)證授權(quán)組件

除了連接器和容器,管道組件和閥門組件也很關(guān)鍵,我們通過一張圖來看看這兩個組件

Tomcat源碼分析:一文帶你整體把握架構(gòu)及組件

Connector和Container的微妙關(guān)系

由上述內(nèi)容我們大致可以知道一個請求發(fā)送到Tomcat之后,首先經(jīng)過Service然后會交給我們的Connector,Connector用于接收請求并將接收的請求封裝為Request和Response來具體處理,Request和Response封裝完之后再交由Container進(jìn)行處理,Container處理完請求之后再返回給Connector,最后在由Connector通過Socket將處理的結(jié)果返回給客戶端,這樣整個請求的就處理完了!

Connector最底層使用的是Socket來進(jìn)行連接的,Request和Response是按照HTTP協(xié)議來封裝的,所以Connector同時需要實現(xiàn)TCP/IP協(xié)議和HTTP協(xié)議!

Connector架構(gòu)分析

Connector用于接受請求并將請求封裝成Request和Response,然后交給Container進(jìn)行處理,Container處理完之后在交給Connector返回給客戶端。

因此,我們可以把Connector分為四個方面進(jìn)行理解:

  1. Connector如何接受請求的?
  2. 如何將請求封裝成Request和Response的?
  3. 封裝完之后的Request和Response如何交給Container進(jìn)行處理的?

首先看一下Connector的結(jié)構(gòu)圖,如下所示:

Tomcat源碼分析:一文帶你整體把握架構(gòu)及組件

Connector就是使用ProtocolHandler來處理請求的,不同的ProtocolHandler代表不同的連接類型,比如:Http11Protocol使用的是普通Socket來連接的,Http11NioProtocol使用的是NioSocket來連接的。

其中ProtocolHandler由包含了三個部件:Endpoint、Processor、Adapter。

  1. Endpoint用來處理底層Socket的網(wǎng)絡(luò)連接,Processor用于將Endpoint接收到的Socket封裝成Request,Adapter用于將Request交給Container進(jìn)行具體的處理。
  2. Endpoint由于是處理底層的Socket網(wǎng)絡(luò)連接,因此Endpoint是用來實現(xiàn)TCP/IP協(xié)議的,而Processor用來實現(xiàn)HTTP協(xié)議的,Adapter將請求適配到Servlet容器進(jìn)行具體的處理。
  3. Endpoint的抽象實現(xiàn)AbstractEndpoint里面定義的Acceptor和AsyncTimeout兩個內(nèi)部類和一個Handler接口。Acceptor用于監(jiān)聽請求,AsyncTimeout用于檢查異步Request的超時,Handler用于處理接收到的Socket,在內(nèi)部調(diào)用Processor進(jìn)行處理。

Container如何處理請求的

Container處理請求是使用Pipeline-Valve管道來處理的?。╒alve是閥門之意)

Pipeline-Valve是責(zé)任鏈模式,責(zé)任鏈模式是指在一個請求處理的過程中有很多處理者依次對請求進(jìn)行處理,每個處理者負(fù)責(zé)做自己相應(yīng)的處理,處理完之后將處理后的請求返回,再讓下一個處理著繼續(xù)處理。

但是!Pipeline-Valve使用的責(zé)任鏈模式和普通的責(zé)任鏈模式有些不同!區(qū)別主要有以下兩點:

  1. 每個Pipeline都有特定的Valve,而且是在管道的最后一個執(zhí)行,這個Valve叫做BaseValve,BaseValve是不可刪除的;
  2. 在上層容器的管道的BaseValve中會調(diào)用下層容器的管道。

我們知道Container包含四個子容器,而這四個子容器對應(yīng)的BaseValve分別在:StandardEngineValve、StandardHostValve、StandardContextValve、StandardWrapperValve。

Pipeline的處理流程圖如下:

Tomcat源碼分析:一文帶你整體把握架構(gòu)及組件

步驟如下:

  1. Connector在接收到請求后會首先調(diào)用最頂層容器的Pipeline來處理,這里的最頂層容器的Pipeline就是EnginePipeline(Engine的管道);
  2. 在Engine的管道中依次會執(zhí)行EngineValve1、EngineValve2等等,最后會執(zhí)行StandardEngineValve,在StandardEngineValve中會調(diào)用Host管道,然后再依次執(zhí)行Host的HostValve1、HostValve2等,最后在執(zhí)行StandardHostValve,然后再依次調(diào)用Context的管道和Wrapper的管道,最后執(zhí)行到StandardWrapperValve。
  3. 當(dāng)執(zhí)行到StandardWrapperValve的時候,會在StandardWrapperValve中創(chuàng)建FilterChain,并調(diào)用其doFilter方法來處理請求,這個FilterChain包含著我們配置的與請求相匹配的Filter和Servlet,其doFilter方法會依次調(diào)用所有的Filter的doFilter方法和Servlet的service方法,這樣請求就得到了處理!
  4. 當(dāng)所有的Pipeline-Valve都執(zhí)行完之后,并且處理完了具體的請求,這個時候就可以將返回的結(jié)果交給Connector了,Connector在通過Socket的方式將結(jié)果返回給客戶端。

總結(jié)

好了,我們已經(jīng)從整體上看到了Tomcat的結(jié)構(gòu),但是對于每個組件我們并沒有詳細(xì)分析。后續(xù)章節(jié)我們會從幾個方面來學(xué)習(xí)Tomcat:

  1. 逐一分析各個組件
  2. 通過斷點的方式來跟蹤Tomcat代碼中的一次完整請求

特別推薦一個分享架構(gòu)+算法的優(yōu)質(zhì)內(nèi)容,還沒關(guān)注的小伙伴,可以長按關(guān)注一下:

Tomcat源碼分析:一文帶你整體把握架構(gòu)及組件

Tomcat源碼分析:一文帶你整體把握架構(gòu)及組件

Tomcat源碼分析:一文帶你整體把握架構(gòu)及組件

長按訂閱更多精彩▼

Tomcat源碼分析:一文帶你整體把握架構(gòu)及組件

如有收獲,點個在看,誠摯感謝

免責(zé)聲明:本文內(nèi)容由21ic獲得授權(quán)后發(fā)布,版權(quán)歸原作者所有,本平臺僅提供信息存儲服務(wù)。文章僅代表作者個人觀點,不代表本平臺立場,如有問題,請聯(lián)系我們,謝謝!

本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內(nèi)容真實性等。需要轉(zhuǎn)載請聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請及時聯(lián)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫?dú)角獸公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

加利福尼亞州圣克拉拉縣2024年8月30日 /美通社/ -- 數(shù)字化轉(zhuǎn)型技術(shù)解決方案公司Trianz今天宣布,該公司與Amazon Web Services (AWS)簽訂了...

關(guān)鍵字: AWS AN BSP 數(shù)字化

倫敦2024年8月29日 /美通社/ -- 英國汽車技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認(rèn)證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時1.5...

關(guān)鍵字: 汽車 人工智能 智能驅(qū)動 BSP

北京2024年8月28日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務(wù)能7×24不間斷運(yùn)行,同時企業(yè)卻面臨越來越多業(yè)務(wù)中斷的風(fēng)險,如企業(yè)系統(tǒng)復(fù)雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務(wù)連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報道,騰訊和網(wǎng)易近期正在縮減他們對日本游戲市場的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會開幕式在貴陽舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導(dǎo)體

8月28日消息,在2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會上,華為常務(wù)董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機(jī) 衛(wèi)星通信

要點: 有效應(yīng)對環(huán)境變化,經(jīng)營業(yè)績穩(wěn)中有升 落實提質(zhì)增效舉措,毛利潤率延續(xù)升勢 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務(wù)引領(lǐng)增長 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競爭力 堅持高質(zhì)量發(fā)展策略,塑強(qiáng)核心競爭優(yōu)勢...

關(guān)鍵字: 通信 BSP 電信運(yùn)營商 數(shù)字經(jīng)濟(jì)

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺與中國電影電視技術(shù)學(xué)會聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會上宣布正式成立。 活動現(xiàn)場 NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會上,軟通動力信息技術(shù)(集團(tuán))股份有限公司(以下簡稱"軟通動力")與長三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉
關(guān)閉