Tomcat 分为很多组件,这些组件一起协同工作。
这些组件包括: Server,Service,Connector,Engine,Host,Context,Wrapper.
这么一堆组件,看起来比较复杂,怎么去理解呢?本文主要来个top level view 。
回到我们最初的对servlet 容器的理解,一个servlet 容器最重要的功能无非就是接受http 请求,解析http 请求生成request ,并调用servlet ,生成响应response 。那么以上工作的入口在哪里,没错,那就是Connector 组件。先来认识一下Connector 组件。
Connector组件
Connector 主要功能是Socket 连接等待Http 请求,创建javax.servlet.http.HttpServletRequest 和javax.servlet.http.HttpServletResponse 实例,并将其作为参数调用容器。当然Connector 并不只处理http 协议的请求,支持多种协议如https ,AJP/1.3 等。不同的Connector 代表了不同的协议,同时在不同的端口上面监听。这个可以再Server.xml 里进行配置。connector的工作就像下图的前半部分:
(上图截自 tomcat developer guide )
从以上看出Connector 负责接受请求和生成request (Request 创建过程:parse header ,parse cookie ,parse parameter 、设置encodeing 等)和response 。再把参数传给容器。最后我们是要由url 请求对应的servlet 的service 方法来接收这两个参数,并处理生成response 。那么后面的load servlet 和invoke servlet 的工作就交给容器来处理了,容器说起来很抽象诶,它代表什么?下面介绍一下Container 。
Container组件
没错,容器只是一个抽象的概念,在tomcat 里Engine,Host,Context,Wrapper 都代表容器。它们各自的功能如下:
Engine :代表了整个Catalina servlet 引擎.
Host: 代表了一个具有多个应用实例(Context) 的虚拟主机( 注:tomcat 里默认只有一个localhost 虚拟主机,所有的请求默认都转发给它,它的应用实例都默认的放在webapps 目录下面。Tomcat 支持多虚拟主机,可以再server.xml 里面进行配置).
Context :代表了一个应用实例,也就是我们平常的一个web 应用。一个Context 有一个或者多个wrappers.
Wrapper: 代表了一个单独的servlet.
有了Connector 和Container(Engine,Host,Context,Wrapper) 似乎一个servlet 容器就可以工作了,那么文章一开始提到的Server 和Service 干啥用的呢?
Service组件
Service 包含了一个Engine 元素和多个Connector 元素。上文提到的connector 有多种,这些connector 可以共享一个servlet 引擎。同时分开运行。而其管理是有service 来管理的。
Server组件
Server 它代表了整个Servlet 容器。它提供了一套启动和停止整个系统的机制。而我们不用去关心内部的原理。它包含了一个或者多个service 实例。当你启动一个server ,它把所有的内部组件都初始化。同时它提供一个监听端口,时刻监听shutdown 命令。并负责整个系统的stop 过程。同时Server 也提供了JNDI 等其他java EE 服务的实现。可以再server 里初始化JNDI 数据源( 在server.xml 里配置) 。
以上包括了tomcat的全部组件,其关系可由下图片表示:
(上图截自 tomcat developer guide )
Server.xml配置文件
关心内部的一个Server起来的时候,它怎么知道要启动哪些Service或Connector?在server起来的时候是通过读取server.xml里的配置来组织和初始化整个容器,也就是说server.xml实际上就代表了一个server实例,它包含了server要在哪个端口上面监听shutdown,server使用哪个类?connector应该包括哪些,各个connector的监听端口和协议是什么?以及有几个host,host名称是什么?host的base目录在哪里?默认的context是哪个?还有Engine、service等等一些列属性。
下面看看一个tomcat默认的server.xml:
- <Server port="8005" shutdown="SHUTDOWN">
-
<Listener className="org.apache.catalina.core.AprLifecycleListener" SSLEngine="on" />
-
<Listener className="org.apache.catalina.core.JasperListener" />
-
<Listener className="org.apache.catalina.mbeans.ServerLifecycleListener" />
-
<Listener className="org.apache.catalina.mbeans.GlobalResourcesLifecycleListener" />
- <!-- Global JNDI resources
- Documentation at /docs/jndi-resources-howto.html
-
-->
-
<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">
-
<Connector port="8080" protocol="HTTP/1.1"
-
maxThreads="150" connectionTimeout="20000"
-
redirectPort="8443" />
-
<Connector port="8009" protocol="AJP/1.3" redirectPort="8443" />
-
<Engine name="Catalina" defaultHost="localhost">
-
<Realm className="org.apache.catalina.realm.UserDatabaseRealm"
-
resourceName="UserDatabase"/>
-
<Host name="localhost" appBase="webapps"
-
unpackWARs="true" autoDeploy="true"
-
xmlValidation="false" xmlNamespaceAware="false">
-
</Host>
-
</Engine>
-
</Service>
- </Server>
最后再发一份关于tomcat的学习资料(How tomcat works.),感觉不错,有需要可以下载研究一下,不过是基于tomcat4、5的。
分享到:
相关推荐
对于tomcat的启动流程分析,从主流程Bootstrap -> Catalina -> Server -> service -> engine,connector;和分流程1.engine->host->context->wrapper ;2.connector -> ProtocolHandler->Endpoint;之中的方法调用进行...
Tomcat 服务器的整体架构是由一系列可配置的组件构成的,其核心组件是 Catalina Servlet 容器,它是所有其他 Tomcat 组件的顶层容器。Tomcat 的组件可以在(conf/server.xml 文件中进行配置,每个 Tomcat 组件在 ...
Tomcat监控工具Probe 1.Porbe介绍 psi-probe用于对Tomcat进行监控,比tomcat的manager强大很多。 2.下载 probe-2.3.3.zip 或者 probe.war 3.将下载好的war包,或者zip文件,放在tomcat的webapp目录下 4...
本书深入剖析Tomcat4和Tomcat5中的每个组件,并揭示其内部工作原理。通过学习本书,你将可以自行开发Tomcat组件,或者扩展已有的组件。Tomcat是目前比较流行的Web服务器之一。作为一个开源和小型的轻量级应用服务器...
Tomcat7、Tomcat8和Tomcat9是不同版本的Tomcat,每个版本都有其特性和改进。 **Tomcat7**: Tomcat7是2011年发布的,它主要支持Java Servlet 3.0和JSP 2.2规范。这个版本引入了一些重要改进,包括增强的安全性、更...
以下将详细介绍Tomcat API的关键概念和关键组件。 1. **Servlet API**: Tomcat作为Servlet容器,核心是Servlet和Servlet API。Servlet是Java编写的小型服务器端程序,负责处理客户端请求并返回响应。Servlet API...
3. **生命周期管理**:每个Tomcat组件都有自己的生命周期,包括初始化、启动、停止和销毁。源码中,这些生命周期方法的实现有助于理解Tomcat的内部工作流程。 4. **部署与加载**:Tomcat可以自动或手动部署Web应用...
1. **Catalina**:这是Tomcat的主要组件,负责处理Servlet和JSP的请求。Catalina实现了Servlet和JSP规范,使得开发者可以使用这些标准来构建Web应用程序。 2. **Jasper**:这是Tomcat中的JSP引擎,用于将JSP页面...
本主题将深入探讨“log4j.jar”,“tomcat-juli.jar”以及“tomcat-juli-adapters.jar”这三款与Tomcat日志相关的组件,它们在Tomcat日志配置中的作用及重要性。 首先,我们来了解`log4j.jar`。Log4j是Apache组织...
**Tomcat工作原理详解——组件解析** Tomcat作为Apache软件基金会的开源项目,是Java Servlet、JavaServer Pages(JSP)和Java Expression Language(EL)的实现,是Web应用程序服务器的首选之一。深入理解Tomcat的...
了解Tomcat的架构,从Connector和Container这两个核心组件开始,理解它们的协同工作方式,以及Tomcat如何通过模块化的设计来管理服务组件的生命周期,对于深入使用和定制Tomcat是非常重要的。同时,观察和学习Tomcat...
- **Engine/Host/Context/Wrapper** 这些组件遵循MVC(Model-View-Controller)设计模式,实现了请求处理的分层解耦。 2. 架构演化史: - 第一代:简单的请求处理,所有工作都在一个组件中完成,职责不明确。 -...
1. **Catalina**:这是Tomcat的主要组件,负责Servlet和JSP的执行。Catalina提供了一个基于容器的架构,可以管理和部署多个Web应用程序。 2. ** Coyote**:这是一个HTTP/1.1协议处理器,负责接收和响应HTTP请求。 ...
本篇文章将详细阐述如何在Windows操作系统上安装和配置JDK、Tomcat以及ActiveMQ,这三个组件是开发和部署Java Web应用程序的基础。 首先,我们从JDK的安装与配置开始。JDK (Java Development Kit) 是开发和运行Java...
这个压缩包文件"tomcat6.0.35_tomcat_"包含了Apache Tomcat 6.0.35版本的所有组件和资源,它是开发者和系统管理员进行Java Web应用开发和部署的重要工具。 ### Tomcat 6.0.35 简介 Tomcat 6.0.35是Tomcat 6系列的...
3. **备份原始文件**:在安装补丁之前,建议先备份Tomcat的配置文件和关键组件,以防万一出现问题时可以迅速恢复。 4. **替换或添加文件**:按照补丁文件中的说明,将补丁文件中的内容复制到Tomcat的相应位置。常见...
Tomcat的核心配置文件之一是`server.xml`,这个文件位于Tomcat的`conf`目录下,它是Tomcat服务器的全局配置文件,定义了服务器的端口号、数据源、连接器、虚拟主机、Context等关键组件的设置。例如,你可以在这里...
3. **Connector组件**:Tomcat通过Connector组件与外部世界进行通信。这些组件负责接收和处理HTTP请求,并将结果返回给客户端。 4. **Context容器**:每个Web应用程序都在一个独立的Context容器中运行,管理应用程序...
Tomcat的主要功能和组件包括: 1. Catalina:这是Tomcat的核心,负责处理Servlet和JSP的请求。 2. Jasper:是Tomcat内建的JSP引擎,负责编译JSP文件为Servlet。 3. JMX Remote Lifecycle Listener:允许远程管理...