作为一款开源的轻量级的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的具体设计过程,但是个人觉得要快速理解它们具体实现之前,了解一下各个构建的加载过程很有必要。
<div align=center>tomcat总体架构图</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请求连接的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源码分析)