tomcat原始碼分析(第一篇 從整體架構開始)

emoo發表於2018-06-27

作為一款開源的輕量級的jsp伺服器軟體,tomcat是使用最廣泛的web伺服器之一。tomcat原始碼用Java編寫,研讀tomcat原始碼,向大師學習程式設計思想,還是會有不少收穫。

一、tomcat總體架構

巨集觀角度來看,tomcat可以分為兩大塊,Connector和Container。Connector主要負責接收請求、解析請求後生成request和response。Container作為伺服器的的處理容器,其主要職責是將請求對映到具體的servlet,在servlet處理完請求後生成response,交給Connector寫入到Socket,返回給客戶端。一個Web應用中可以有多個Connector容器(預設情況下,在server.xml中設定了兩個Connector,分別對應處理不同的請求,普通HTTP請求8080埠和AJP協議的8009埠),但只有一個根Container(即Engine)。Connector和Container構成了一個Service服務,最後Server作為Service的父結構,負責整個service的生命週期。Serve、Service、Connector、Connector之間的關係可以從server.xml檔案中表現出來(見程式碼清單1)。tomcat的整體架構如下圖所示。下面就著重mark一下Service、Connector、Container的具體設計過程,但是個人覺得要快速理解它們具體實現之前,瞭解一下各個構建的載入過程很有必要。

tomcat總體架構圖

tomcat原始碼分析(第一篇 從整體架構開始)

程式碼清單1
<Server port="8005" shutdown="SHUTDOWN" 
  <Listener className="org.apache.catalina.startup.VersionLoggerListener" />
  <Listener className="org.apache.catalina.core.AprLifecycleListener" SSLEngine="on" />
  <Listener className="org.apache.catalina.core.JreMemoryLeakPreventionListener" />
  <Listener className="org.apache.catalina.mbeans.GlobalResourcesLifecycleListener" />
  <Listener className="org.apache.catalina.core.ThreadLocalLeakPreventionListener" />
  <GlobalNamingResources>
    <Resource name="UserDatabase" auth="Container"
              type="org.apache.catalina.UserDatabase"
              description="User database that can be updated and saved"
              factory="org.apache.catalina.users.MemoryUserDatabaseFactory"
              pathname="conf/tomcat-users.xml" />
  </GlobalNamingResources>
  <Service name="Catalina">
    <!--處理HTTP請求連線的Connector,埠號為8080-->
    <Connector port="8080" protocol="HTTP/1.1"
               connectionTimeout="20000"
               redirectPort="8443" />
    <!--處理AJP請求連線的Connector,埠號為8443-->
    <Connector port="8009" 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"
            unpackWARs="true" autoDeploy="true">
        <Valve className="org.apache.catalina.valves.AccessLogValve" directory="logs"
               prefix="localhost_access_log" suffix=".txt"
               pattern="%h %l %u %t &quot;%r&quot; %s %b" />
      </Host>
    </Engine>
  </Service>
</Server>
複製程式碼

tomcat原始碼分析(第二篇 tomcat啟動過程詳解)
tomcat原始碼分析(第三篇 tomcat請求原理解析--Connector原始碼分析)
tomcat原始碼分析(第四篇 tomcat請求處理原理解析--Container原始碼分析)

相關文章