咱們想要了解一個框架,首先要了解它是幹什麼的,Tomcat咱們都知道,是用於處理鏈接過來的Socket請求的。那麼Tomcat就會有兩個功能:web
那麼咱們總體的骨架就出來了,Tomcat其實就分爲兩大部分,一部分是鏈接器(Connnector)處理對外鏈接和容器(Container)管理對內的Servelet。apache
大致的關係圖以下:設計模式
描述:瀏覽器
最外層的大框就是表明一個Tomcat服務,一個Tomcat服務能夠對應多個Service。每一個Service都有鏈接器和容器。網絡
這些對應的關係咱們也能夠打開在Tomcat目錄配置文件中 server.xml
中看出來。架構
<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"/> </Realm> <Host name="localhost" appBase="webapps"></Host> </Engine> </Service> </Server>
這裏咱們能夠看到鏈接器其實就是 Connector
,一個Service中能夠有多個鏈接器,容器其實對應的就是 Engine
。app
Tomcat的總體架構簡單來講就是這樣的對應關係。接下來咱們簡單的介紹鏈接器的總體架構和容器的總體架構。框架
咱們能夠看到上圖中鏈接器傳給容器的是 ServletRequest
對象,而容器傳給鏈接器的是 ServletResponse
對象,這些在網絡傳輸過程當中是確定不行的,由於網絡傳輸中傳送的字節流。webapp
因此鏈接器的功能需求咱們大概能總結出來如下幾點。ide
TomcatRequest
t對象TomcatReques
傳給容器TomcatResponse
對象TomcatResponse
對象轉換爲字節流其實上面的細分都能總結爲如下的三點
Request/Response
與 ServletRequest/ServletResponse
對象的轉化而在Tomcat中它也用了三個類來實現上面的三個功能,分別對應以下
用圖表示他們的關係的話就是這樣
容器,顧名思義就是裝東西的器具,那麼這個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
。
咱們在瀏覽器上輸入 http://localhost:8080/buxuewushu/add.do
是如何找到對應Servlet進行處理呢?
在咱們啓動Tomcat的時候,鏈接器就會進行初始化監聽所配置的端口號,這裏咱們配置的是8080端口對應的協議是HTTP。
ServletRequest
對象給同級 Service
下的容器模塊Engine進行處理http://localhost:8080/buxuewushu/add
。匹配他下面的Host主機/buxuewushu
的Context,即在webapp下面找到相應的文件夾doGet
或者 doPost
方法