做爲一款開源的輕量級的jsp服務器軟件,tomcat是使用最普遍的web服務器之一。tomcat源碼用Java編寫,研讀tomcat源碼,向大師學習編程思想,仍是會有很多收穫。web
宏觀角度來看,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的具體設計過程,可是我的以爲要快速理解它們具體實現以前,瞭解一下各個構建的加載過程頗有必要。apache
<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 "%r" %s %b" />
</Host>
</Engine>
</Service>
</Server>
複製代碼
tomcat源碼分析(第二篇 tomcat啓動過程詳解)
tomcat源碼分析(第三篇 tomcat請求原理解析--Connector源碼分析)
tomcat源碼分析(第四篇 tomcat請求處理原理解析--Container源碼分析)
編程