作為一款開(kāi)源的輕量級(jí)的jsp服務(wù)器軟件,tomcat是使用最廣泛的web服務(wù)器之一。tomcat源碼用Java編寫(xiě),研讀tomcat源碼,向大師學(xué)習(xí)編程思想,還是會(huì)有不少收獲。
一、tomcat總體架構(gòu)
宏觀角度來(lái)看,tomcat可以分為兩大塊,Connector和Container。Connector主要負(fù)責(zé)接收請(qǐng)求、解析請(qǐng)求后生成request和response。Container作為服務(wù)器的的處理容器,其主要職責(zé)是將請(qǐng)求映射到具體的servlet,在servlet處理完請(qǐng)求后生成response,交給Connector寫(xiě)入到Socket,返回給客戶端。一個(gè)Web應(yīng)用中可以有多個(gè)Connector容器(默認(rèn)情況下,在server.xml中設(shè)置了兩個(gè)Connector,分別對(duì)應(yīng)處理不同的請(qǐng)求,普通HTTP請(qǐng)求8080端口和AJP協(xié)議的8009端口),但只有一個(gè)根Container(即Engine)。Connector和Container構(gòu)成了一個(gè)Service服務(wù),最后Server作為Service的父結(jié)構(gòu),負(fù)責(zé)整個(gè)service的生命周期。Serve、Service、Connector、Connector之間的關(guān)系可以從server.xml文件中表現(xiàn)出來(lái)(見(jiàn)代碼清單1)。tomcat的整體架構(gòu)如下圖所示。下面就著重mark一下Service、Connector、Container的具體設(shè)計(jì)過(guò)程,但是個(gè)人覺(jué)得要快速理解它們具體實(shí)現(xiàn)之前,了解一下各個(gè)構(gòu)建的加載過(guò)程很有必要。
<div align=center>tomcat總體架構(gòu)圖</div>
<div align=center>代碼清單1</div>
<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請(qǐng)求連接的Connector,端口號(hào)為8080-->
<Connector port="8080" protocol="HTTP/1.1"
connectionTimeout="20000"
redirectPort="8443" />
<!--處理AJP請(qǐng)求連接的Connector,端口號(hào)為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啟動(dòng)過(guò)程詳解)
tomcat源碼分析(第三篇 tomcat請(qǐng)求原理解析--Connector源碼分析)
tomcat源碼分析(第四篇 tomcat請(qǐng)求處理原理解析--Container源碼分析)