tomcat整体架构简介

193 阅读1分钟

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

image

代码清单1

<Server port="8005" shutdown="SHUTDOWN"

  <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>