作为一款开源的轻量级的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总体架构图
<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>