【Tomcat学习笔记】整体架构

栏目: 服务器 · 发布时间: 7年前

内容简介:【Tomcat学习笔记】整体架构

Tomcat的整体架构其实和 server.xml 这个配置文件是可以对应起来的。这是一个最简单的但是能用的 server.xml

<?xml version='1.0' encoding='utf-8'?>
<Serverport="8005"shutdown="SHUTDOWN">
  <ListenerclassName="org.apache.catalina.startup.VersionLoggerListener"/>
  <ListenerclassName="org.apache.catalina.core.AprLifecycleListener"SSLEngine="on"/>
  <ListenerclassName="org.apache.catalina.core.JreMemoryLeakPreventionListener"/>
  <ListenerclassName="org.apache.catalina.mbeans.GlobalResourcesLifecycleListener"/>
  <ListenerclassName="org.apache.catalina.core.ThreadLocalLeakPreventionListener"/>

  <GlobalNamingResources>
    <Resourcename="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>

  <Servicename="Catalina">

    <Connectorport="8080"protocol="HTTP/1.1"connectionTimeout="20000"redirectPort="8443"/>
    <Connectorport="8009"protocol="AJP/1.3"redirectPort="8443"/>

    <Enginename="Catalina"defaultHost="localhost">
      <RealmclassName="org.apache.catalina.realm.LockOutRealm">
        <RealmclassName="org.apache.catalina.realm.UserDatabaseRealm"
               resourceName="UserDatabase"/>
      </Realm>

      <Hostname="localhost"appBase="webapps"
            unpackWARs="true" autoDeploy="true">

        <ValveclassName="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学习笔记】整体架构

代码和 server.xml 这个配置文件一样,也是一样的层级结构,Server > Service > Engine > Host > Context > Wrapper 是依次包含的关系。Tomcat 里也定义了同样名字的 Interface, 这些接口的默认实现是 StandardServer > StandardService > StandardEngine > StandardHost > StandardContext > StandardWrapper。这个类图是Tomcat最主要的一个结构:

【Tomcat学习笔记】整体架构

关于这个架构图,有几点需要说明,但细节可能需要后面写具体的笔记分析(立个flag在这,打脸)

  • Server 和 Service 并不是 Container(容器), 它们不像其它容器那样有Valve
  • 每个组件都可以配置很多 Listener, 这些 Listener 都实现了 LifecycleListener 接口,每个组件在经历生命周期的每个阶段的时候都会去循环通知这些 Listener
  • 每个组件都实现了生命周期 Lifecycle 接口 (关于组件的生命周期,后面应该可以单独整理一个笔记的)
  • Context 和 Wrapper 在 server.xml 中并没有配置(要配置应该也是可以的吧,待确认),
    【Tomcat学习笔记】整体架构 【图片来源】( http://gearever.iteye.com/blog/1532822 ), Host对应www.mydomain.com那一层,在 Tomcat 启动之前就知道的。Context 对应 app 那一层,这个 app 是 Tomcat 在启动过程中,扫描 catalina-home/webapps(默认是这个目录) 这个目录的时候才知道有哪几个应用需要部署,才创建对应的 Context, 所以这个是可以不在 server.xml 中配置的。可以理解成一个 Java 应用 对应一个 Context. 那么 Wrapper 也是在扫描了待部署应用里面的内容后才创建的。Engine 和 Host 则是启动过程中通过解析 server.xml 的时候创建的。
  • Engine、Host、Context、Wrapper 四种 Container 都可以配置 Valve ,即使不配置,每个 Container 代码里都有默认的Valve(StandardEngineValve, StandardHostValve …)是处理请求的时候必须经过的。关于 Pipeline 和 Valve,就是一个水管中间有多个阀门,每个数据流过来都在阀门的地方被处理一下。 四个容器的Pipeline串起来,可以用张图来描述一下:
    【Tomcat学习笔记】整体架构 实际代码中并没有这样一个 Pipeline 的数据结构或者类, 这只是一个抽象概念,代码里就是类似于链表的形式,getNext().getNext()这样.请求request进到 Engine 后,会经过几个Valve的处理,然后会选择一个 Host,进入它的 Valve 链里进行处理,后面也是按这种方式进行,响应数据最后也是按这个路径原路返回的。和现实中的 Pipeline最大的不同是,现实中的水管谁到了这里之后是分流分到下面几个细的水管,这里不是,这是是选择一根Pipeline。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

神经网络与机器学习(原书第3版)

神经网络与机器学习(原书第3版)

[加] Simon Haykin / 申富饶、徐烨、郑俊、晁静 / 机械工业出版社 / 2011-3 / 79.00元

神经网络是计算智能和机器学习的重要分支,在诸多领域都取得了很大的成功。在众多神经网络著作中,影响最为广泛的是Simon Haykin的《神经网络原理》(第3版更名为《神经网络与机器学习》)。在本书中,作者结合近年来神经网络和机器学习的最新进展,从理论和实际应用出发,全面、系统地介绍了神经网络的基本模型、方法和技术,并将神经网络和机器学习有机地结合在一起。 本书不但注重对数学分析方法和理论的探......一起来看看 《神经网络与机器学习(原书第3版)》 这本书的介绍吧!

MD5 加密
MD5 加密

MD5 加密工具

XML 在线格式化
XML 在线格式化

在线 XML 格式化压缩工具

Markdown 在线编辑器
Markdown 在线编辑器

Markdown 在线编辑器