四張圖帶你了解Tomcat系統架構

俗話說,站在巨人的肩膀上看世界,一般學習的時候也是先總覽一下整體,然后逐個部分個個擊破,最后形成思路,了解具體細節,Tomcat的結構很復雜,但是 Tomcat 非常的模塊化,找到了 Tomcat最核心的模塊,問題才可以游刃而解,了解了Tomcat的整體架構對以后深入了解Tomcat來說至關重要!

一、Tomcat頂層架構

先上一張Tomcat的頂層結構圖(圖A),如下:

Tomcat中最頂層的容器是Server,代表著整個服務器,從上圖中可以看出,一個Server可以包含至少一個Service,用于具體提供服務。

Service主要包含兩個部分:Connector和Container。從上圖中可以看出 Tomcat 的心臟就是這兩個組件,他們的作用如下:

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

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

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

另外,上述的包含關系或者說是父子關系,都可以在tomcat的conf目錄下的server.xml配置文件中看出,下圖是刪除了注釋內容之后的一個完整的server.xml配置文件(Tomcat版本為8.0)

詳細的配置文件文件內容可以到Tomcat官網查看:http://tomcat.apache.org/tomcat-8.0-doc/index.html

上邊的配置文件,還可以通過下邊的一張結構圖更清楚的理解:

Server標簽設置的端口號為8005,shutdown=”SHUTDOWN” ,表示在8005端口監聽“SHUTDOWN”命令,如果接收到了就會關閉Tomcat。一個Server有一個Service,當然還可以進行配置,一個Service有多個,Service左邊的內容都屬于Container的,Service下邊是Connector。

二、Tomcat頂層架構小結:

(1)Tomcat中只有一個Server,一個Server可以有多個Service,一個Service可以有多個Connector和一個Container;

(2) Server掌管著整個Tomcat的生死大權;

(4)Service 是對外提供服務的;

(5)Connector用于接受請求并將請求封裝成Request和Response來具體處理;

(6)Container用于封裝和管理Servlet,以及具體處理request請求;

知道了整個Tomcat頂層的分層架構和各個組件之間的關系以及作用,對于絕大多數的開發人員來說Server和Service對我們來說確實很遠,而我們開發中絕大部分進行配置的內容是屬于Connector和Container的,所以接下來介紹一下Connector和Container。

三、Connector和Container的微妙關系

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

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

Tomcat既然處理請求,那么肯定需要先接收到這個請求,接收請求這個東西我們首先就需要看一下Connector!

四、Connector架構分析

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

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

(1)Connector如何接受請求的? (2)如何將請求封裝成Request和Response的? (3)封裝完之后的Request和Response如何交給Container進行處理的? (4)Container處理完之后如何交給Connector并返回給客戶端的?

首先看一下Connector的結構圖(圖B),如下所示:

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

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

(1)Endpoint用來處理底層Socket的網絡連接,Processor用于將Endpoint接收到的Socket封裝成Request,Adapter用于將Request交給Container進行具體的處理。

(2)Endpoint由于是處理底層的Socket網絡連接,因此Endpoint是用來實現TCP/IP協議的,而Processor用來實現HTTP協議的,Adapter將請求適配到Servlet容器進行具體的處理。

(3)Endpoint的抽象實現AbstractEndpoint里面定義的Acceptor和AsyncTimeout兩個內部類和一個Handler接口。Acceptor用于監聽請求,AsyncTimeout用于檢查異步Request的超時,Handler用于處理接收到的Socket,在內部調用Processor進行處理。

至此,我們應該很輕松的回答(1)(2)(3)的問題了,但是(4)還是不知道,那么我們就來看一下Container是如何進行處理的以及處理完之后是如何將處理完的結果返回給Connector的?

五、Container架構分析

Container用于封裝和管理Servlet,以及具體處理Request請求,在Connector內部包含了4個子容器,結構圖如下(圖C):

4個子容器的作用分別是:

(1)Engine:引擎,用來管理多個站點,一個Service最多只能有一個Engine; (2)Host:代表一個站點,也可以叫虛擬主機,通過配置Host就可以添加站點; (3)Context:代表一個應用程序,對應著平時開發的一套程序,或者一個WEB-INF目錄以及下面的web.xml文件; (4)Wrapper:每一Wrapper封裝著一個Servlet;

下面找一個Tomcat的文件目錄對照一下,如下圖所示:

288351179

Context和Host的區別是Context表示一個應用,我們的Tomcat中默認的配置下webapps下的每一個文件夾目錄都是一個Context,其中ROOT目錄中存放著主應用,其他目錄存放著子應用,而整個webapps就是一個Host站點。

我們訪問應用Context的時候,如果是ROOT下的則直接使用域名就可以訪問,例如:www.ledouit.com,如果是Host(webapps)下的其他應用,則可以使用www.ledouit.com/docs進行訪問,當然默認指定的根應用(ROOT)是可以進行設定的,只不過Host站點下默認的主營用是ROOT目錄下的。

看到這里我們知道Container是什么,但是還是不知道Container是如何進行處理的以及處理完之后是如何將處理完的結果返回給Connector的?別急!下邊就開始探討一下Container是如何進行處理的! 如果你在學習Java的過程中或者在工作中遇到什么問題都可以來群里提問,阿里Java高級大牛直播講解知識點,分享知識,文章圖片描述找QQ群,多年工作經驗的梳理和總結,帶著大家全面、科學地建立自己的技術體系和技術認知!可以加群找我要課堂鏈接 注意:是免費的 沒有開發經驗誤入哦! 非喜勿入!

六、Container如何處理請求的

Container處理請求是使用Pipeline-Value管道來處理的!

Pipeline-Value是責任鏈模式,責任鏈模式是指在一個請求處理的過程中有很多處理者依次對請求進行處理,每個處理者負責做自己相應的處理,處理完之后將處理后的請求返回,再讓下一個處理著繼續處理。

但是!Pipeline-Value使用的責任鏈模式和普通的責任鏈模式有些不同!區別主要有以下兩點:

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

我們知道Container包含四個子容器,而這四個子容器對應的BaseValue分別在:StandardEngineValue、StandardHostValue、StandardContextValue、StandardWrapperValue。

Pipeline的處理流程圖如下(圖D):

(1)Connector在接收到請求后會首先調用最頂層容器的Pipeline來處理,這里的最頂層容器的Pipeline就是EnginePipeline(Engine的管道);

(2)在Engine的管道中依次會執行EngineValue1、EngineValue2等等,最后會執行StandardEngineValue,在StandardEngineValue中會調用Host管道,然后再依次執行Host的HostValue1、HostValue2等,最后在執行StandardHostValue,然后再依次調用Context的管道和Wrapper的管道,最后執行到StandardWrapperValue。

(3)當執行到StandardWrapperValue的時候,會在StandardWrapperValue中創建FilterChain,并調用其doFilter方法來處理請求,這個FilterChain包含著我們配置的與請求相匹配的Filter和Servlet,其doFilter方法會依次調用所有的Filter的doFilter方法和Servlet的service方法,這樣請求就得到了處理!

(4)當所有的Pipeline-Value都執行完之后,并且處理完了具體的請求,這個時候就可以將返回的結果交給Connector了,Connector在通過Socket的方式將結果返回給客戶端。

?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 229,565評論 6 539
  • 序言:濱河連續發生了三起死亡事件,死亡現場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發現死者居然都...
    沈念sama閱讀 99,115評論 3 423
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 177,577評論 0 382
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 63,514評論 1 316
  • 正文 為了忘掉前任,我火速辦了婚禮,結果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 72,234評論 6 410
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發上,一...
    開封第一講書人閱讀 55,621評論 1 326
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,641評論 3 444
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 42,822評論 0 289
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當地人在樹林里發現了一具尸體,經...
    沈念sama閱讀 49,380評論 1 335
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 41,128評論 3 356
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發現自己被綠了。 大學時的朋友給我發了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 43,319評論 1 371
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,879評論 5 362
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質發生泄漏。R本人自食惡果不足惜,卻給世界環境...
    茶點故事閱讀 44,548評論 3 348
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 34,970評論 0 28
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 36,229評論 1 291
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 52,048評論 3 397
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 48,285評論 2 376

推薦閱讀更多精彩內容