Tomcat是如何執行的?整體架構又是怎樣的?
作者:不學無數的程式設計師
連結:
在許多的高階開發的崗位中都會或多或少有要求面試人員要研究過一些常用中介軟體原始碼。這是因為一切的秘密都是藏在原始碼中,閱讀原始碼能夠讓我們對框架或者中介軟體的理解更加深刻,而我們也能夠在原始碼的研究中獲得其中一些優秀的設計方式。
而我們的中介軟體和原始碼那麼多,我們該從何入手呢?其實大部分的中介軟體或者框架都有一些共性的部分,例如網路程式設計、多執行緒、反射和類載入等技術。所以深入研究透了一兩個中間價的話,那麼再回過頭來看其他的中介軟體,那麼就會很容易理解它裡面所用的技術以及原理。而作為一個老牌的WEB端框架Tomcat,無論是其整體的架構設計,還是其內在的一些技術靈活應用,都值得我們一看。
在學習框架的時候,我一般都是對這個框架有一個整體的認識。知道它整體是如何執行的,然後再深入其中某部分進行研究,這樣會事半功倍。
# 整體架構
我們想要了解一個框架,首先要了解它是幹什麼的,Tomcat我們都知道,是用於處理連線過來的Socket請求的。那麼Tomcat就會有兩個功能:
對外處理連線,將收到的位元組流轉化為自己想要的Request和Response物件
對內處理Servlet,將對應的Request請求分發到相應的Servlet中
那麼我們整體的骨架就出來了,Tomcat其實就分為兩大部分,一部分是聯結器(Connnector)處理對外連線和容器(Container)管理對內的Servelet。大體的關係圖如下
<Server port="8006" shutdown="SHUTDOWN">
<Service name="Catalina">
<Connector port="8080" protocol="HTTP/1.1"
connectionTimeout="20000"
redirectPort="8443" />
<Connector port="8010" protocol="AJP/1.3" redirectPort="8443" />
<Engine name="Catalina" defaultHost="localhost">
<Realm className="org.apache.catalina.realm.LockOutRealm">
<Realm className="org.apache.catalina.realm.UserDatabaseRealm"
resourceName="UserDatabase"/>
<Host name="localhost" appBase="webapps"
這裡我將其中配置檔案中刪除了一些內容精簡了一下,這裡我們可以看到聯結器其實就是Connector,一個Service中可以有多個聯結器,容器其實對應的就是Engine。
Tomcat的整體架構簡單來說就是這樣的對應關係。接下來我們簡單的介紹聯結器的整體架構和容器的整體架構。
# 聯結器
我們可以看到上圖中聯結器傳給容器的是ServletRequest物件,而容器傳給聯結器的是ServletResponse物件,這些在網路傳輸過程中是肯定不行的,因為網路傳輸中傳送的位元組流。所以聯結器的功能需求我們大概能總結出來以下幾點。
Socket連線
讀取請求網路中的位元組流
根據相應的協議(Http/AJP)解析位元組流,生成統一的Tomcat Requestt物件
將Tomcat Reques傳給容器
容器返回Tomcat Response物件
將Tomcat Response物件轉換為位元組流
將位元組流返回給客戶端
其實上面的細分都能總結為以下的三點
網路通訊
應用層協議的解析
Tomcat的Request/Response與ServletRequest/ServletResponse物件的轉化
而在Tomcat中它也用了三個類來實現上面的三個功能,分別對應如下
EndPoint
Processor
Adapter
用圖表示他們的關係的話就是這樣
# 容器
容器,顧名思義就是裝東西的器具,那麼這個Tomcat容器是裝什麼的呢?其實主要的就是裝了Servlet的。那麼容器是如何設計的呢?Tomcat的容器設計其實是用了組合設計,其實從Server.xml中我們也能看到其關係了。
<Engine name="Catalina" defaultHost="localhost">
<Host name="localhost" appBase="webapps"
unpackWARs="true" autoDeploy="true">
Host>
Engine>
在這裡面我們只能看到容器中的兩個模組,一個是頂層模組Engine,另一個是Host,其實還有兩個模組,一個是Context對應的是我們webapp裡面的每個應用資料夾,每個資料夾就是對應一個Context,還有一個模組Wrapper對應的是我們Context中的所有servlet,Wrapper管理了訪問關係與具體的Servlet的對應。圖表示就是下面這樣。
Tomcat中容器所有模組都實現了Container介面,而組合模式的意義就是使得使用者對於單個物件和組合物件的使用具有一致性,即無論新增多少個Context其使用就是為了找到其下面的Servlet,而無論新增多少個Host也是為了找個下面的Servlet。而在容器中設計了這麼多的模組,一個請求過來Tomcat如何找到對應的Servlet進行處理呢?
# 請求如何定位
我們就舉個最簡單的例子,我們本機應用上啟動了一個Tomcat,webapp下有我們部署的一個應用buxuewushu。我們在瀏覽器上輸入是如何找到對應Servlet進行處理呢?
在我們啟動Tomcat的時候,聯結器就會進行初始化監聽所配置的埠號,這裡我們配置的是8080埠對應的協議是HTTP。
請求傳送到本機的8080埠,被在那裡監聽的HTTP/1.1的聯結器Connector獲得
聯結器Connector將位元組流轉換為容器所需要的ServletRequest物件給同級Service下的容器模組Engine進行處理
Engine獲得地址。匹配他下面的Host主機
匹配到名為localhost的Host(就算此時請求為具體的ip,沒有配置相應的Host,也會交給名為localhost的Host進行處理,因為他是預設的主機)
Host匹配到路徑為/buxuewushu的Context,即在webapp下面找到相應的資料夾
Context匹配到URL規則為*.do的servlet,對應為某個Servlet類
呼叫其doGet或者doPost方法
Servlet執行完以後將物件返回給Context
Context返回給Host
Host返回給Engine
Engine返回給聯結器Connector
聯結器Connector將物件解析為位元組流傳送給客戶端
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/31557372/viewspace-2678712/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- Tomcat的整體架構Tomcat架構
- 死磕Tomcat系列(1)——整體架構Tomcat架構
- JS是怎樣執行的JS
- Webpack 是怎樣執行的?Web
- 飛騰cpu是什麼架構 飛騰cpu整體效能怎樣架構
- sdn專線架構是怎樣的?如何工作?——Vecloud架構Cloud
- Webpack 是怎樣執行的?(一)Web
- 執行緒池是怎樣工作的?執行緒
- 讀《mysql是怎樣執行的》有感MySql
- Linux核心的整體架構Linux架構
- 【Tomcat 原始碼系列】Tomcat 整體結構Tomcat原始碼
- Tomcat 體系架構Tomcat架構
- newsql新品TiDB的整體架構SQLTiDB架構
- Tomcat總體架構(一)Tomcat架構
- nginx 整體架構Nginx架構
- grafana 的主體架構是如何設計的?Grafana架構
- 我們需要怎樣的湖倉一體架構?架構
- 淺析MyBatis(一):由一個快速案例剖析MyBatis的整體架構與執行流程MyBatis架構
- 務實的軟體架構師是什麼樣?(tpierrain)架構AI
- 01 | 基礎架構:一條SQL查詢語句是如何執行的?架構SQL
- 怎樣成長為優秀的軟體架構師?架構
- Dubbo框架————整體架構框架架構
- 專案-整體架構架構
- Netty整體架構解析Netty架構
- 鴻篇鉅製 —— LevelDB 的整體架構架構
- REST是什麼?RESTFul又是什麼?這二者的關係是怎樣的?REST
- tomcat原始碼分析(第一篇 從整體架構開始)Tomcat原始碼架構
- 珠海區塊鏈交易所開發的構架是怎樣的區塊鏈
- 初探Tomcat的架構設計Tomcat架構
- 怎樣停止一個正在執行的執行緒執行緒
- 雲端計算儲存之Ceph架構是怎麼樣的?架構
- Java是值傳遞還是引用傳遞,又是怎麼體現的Java
- 什麼是數字化工廠?數字化工廠的整體架構是什麼?架構
- TiDB整體架構介紹TiDB架構
- 4.3. Oracle整體架構Oracle架構
- Flutter系列(三) 整體架構Flutter架構
- SQL是如何執行的SQL
- 《MySQL是怎樣執行的:從根兒上理解 MySQL》PDFMySql