How Tomcat works — 二、tomcat启动(1)

主要介绍tomcat启动涉及到的一些接口和类。

目录

  • 概述
  • tomcat包含的组件
  • Lifecycle
  • Container
  • Connector
  • 总结

概述

tomcat作为一个服务器,它的主要功能就是接收请求——处理请求——返回,如果是我们自己实现一个最简单的服务器,启动一个线程监听某个端口,该端口有数据进来的话就接收数据,然后在启动一个线程去处理接收到的数据并返回。那么启动一个服务器最重要的就是启动一个线程监听某个端口,tomcat也是,只不过tomcat包含很多组件,首先要完成组件的初始化,然后再依次启动各个组件。所以要知道tomcat 的启动过程,首先了解下tomcat的组件。

tomcat包含的组件

  • Lifecycle:管理整个tomcat的生命周期,包括start,stop。tomcat所有的组件都实现了该接口(或者继承了实现该接口的类)
  • Container:tomcat中最重要的部分,servlet的容器
  • Connector:tomcat的连接器,负责监听端口,接收请求并分发请求

其实还包括Processor、Session、Manager、Deployer等,但是在启动过程中,这些不是最重要的,在了解了整个过程之后在进行具体学习。

Lifecycle

生命周期组件里面主要包含一个接口、一个类、一个enum:Lifecycle、LifecycleEvent、LifecycleState。

Lifecycle接口

接口org.apache.catalina.Lifecycle包含以下定义:

  • 管理生命周期的基本方法,如:start,stop
  • 对于组件listener的管理
  • 组件生命周期内可能会触发的事件,如:START_EVENT,STOP_EVENT等,每一个常量字符串对应一种LifecycleEvent

抽象类LifecycleBase实现了Lifecycle接口,主要提供了基本的start和stop实现,并增加了以下方法

  • 关于事件的:fireLifecycleEvent(protect,可以被子类重载、使用),用来触发该组件的所有Listener
  • 关于初始化子组件的:initInternal(protect),startInternal(protect)等,因为在tomcat的许多组件都是父子关系(比如:Engine和Host),这也是tomcat生命周期管理优雅的地方:每个组件负责启动自己的子组件或者相关组件(监听了该组件的某些事件START_EVENT等),所以tomcat只要启动最顶层的组件即可

抽象类LifecycleMBeanBase继承了LifecycleBase类,这个类实现了LifecycleBase的一些方法,提供了一些MBean的基本管理,tomcat提供了对JMX的支持。

LifecycleEvent类

org.apache.catalina.LifecycleEvent 继承自 java.util.EventObject ,表示lifecycle触发的事件,和事件紧密关联的就是listener了,所有想感知组件生命周期状态变化的类都要事先这个接口 (org.apache.catalina.LifecycleListener) 来监听对应的事件。事实上比如ContextConfig的初始化就是监听了Context的事件。

LifecycleEnum

提供了lifecycle的变化的各种状态,参考下图(tomcat javadoc

Container

其实tomcat作为servlet容器作重要的部分就是Container组件,Container组件是四层架构,类图如下:

简单介绍容器的四层架构:

  • Engine:在catalina容器架构中不是必要的,但是如果要使用一定是处于容器的最顶层,下面有一个或者多个Host(虚拟主机),engine负责将请求分发给对应的虚拟主机
  • Host:表示一个虚拟主机,下面有一个或者多个Context,Host负责将请求分发给对应的Context
  • Context:表示一个webapp,下面有一个或者多个Wrapper,负责将请求映射到对应的Wrapper
  • Wrapper:表示一个servlet,负责加载和初始化servlet

Connector

在刚开始我们说过了,自己实现服务器的话就是监听一个端口,接收请求,这也是tomcat Connector组件的作用,最后监听端口是由JIoEndpoint的一个内部类Acceptor来完成的,所以当JIoEndpoint$Acceptor线程启动的时候,整个tomcat服务器也就启动完成了。

tomcat支持http和ajp协议,所以提供了Http11Protocol和AjpProtocol来处理对应的协议(上面主要画出了http协议的部分)。

总结

以上是tomcat启动所涉及到的主要类和接口,当然了其中涉及到的远不止于此,但是一开始我也说了对于不同的目的,可以有针对性的学习,所以以上只关注了一些户主要的类。还有一个问题就是,我还是有点纠结的:其实我觉得记录的时候没有必要添加大段代码,因为这些代码都比较好懂,而且如果真要阅读的话可以随时找得到,当然了,对于一些很是重要或者经典的代码还是很有必要专门分析的。

在阅读的过程中记了一些笔记和绘制了一些图(这些在tomcat源码阅读的最后再附上),但是感觉都比较琐碎,经过这么一整理感觉更加明晰了。

时间: 2024-10-06 15:12:58

How Tomcat works — 二、tomcat启动(1)的相关文章

Tomcat专题(二)-----Tomcat源码、嵌入式Tomcat

Tomcat顶层结构 Server:服务器的意思,代表整个tomcat服务 器,一个tomcat只有一个Server: Service:Server中的一个逻辑功能层, 一个 Server可以包含多个Service: Connector:称作连接器,是Service的核心组 件之一,一个Service可以有多个Connector, 主要是连接客户端请求: Container:Service的另一个核心组件,按照 层级有Engine,Host,Context,Wrapper四种, 一个Servic

How Tomcat works — 四、tomcat启动(3)

上一节说到StandardService负责启动其子组件:container和connector,不过注意,是有先后顺序的,先启动container,再启动connector,这一节先来看看container. 目录 Pipeline和Vavle StandardEngine类和StandardHost类 StandardContext类 总结 Pipeline和Vavle 在第二节(How Tomcat works — 二.tomcat启动(1))中没有介绍关于Pipeline和Vavle,因

《How Tomcat Works》读书笔记(二)

<How Tomcat Works>读书笔记(二) 这是<How Tomcat Works>第一二章的读书笔记.第一张主要写了一个静态资源处理的web服务器,第二章加了对servlet的处理. 1. 概述 1.1 架构 HttpServer:表示Http服务器,与客户端通信,处理Http请求. StaticResourceProcessor:对静态资源请求进行处理. ServletProcessor:对Servlet资源请求进行处理. Request:表示Http请求,实现了Ser

how tomcat works 读书笔记(二)----------一个简单的servlet容器

app1 (建议读者在看本章之前,先看how tomcat works 读书笔记(一)----------一个简单的web服务器 http://blog.csdn.net/dlf123321/article/details/39378157) 回顾我们上一章,我们开发了一个最最简单的web服务器,它可以使用户访问服务器内的静态资源.当然这是远远不够的,在这一节里,我们就试着让服务器在能相应静态资源的基础上继续支持servlet. servlet接口 javax.servlet.Servlet接口

How Tomcat works — 三、tomcat启动(2)

在了解了tomcat 的一些基本组件之后,学习启动过程就更容易理解了,因为启动过程就是启动各个组件. 目录 启动顺序 Bootstrap类 Catalina类 StandardServer类和StandardService类 总结 启动顺序 tomcat的启动主要是容器的启动,根据tomcat四层架构,启动时由上而下的,而service包含这些组件,service又包含在server里面,启动顺序如下: Bootstrap类 整个tomcat程序的入口——main函数,主要作用就是找到CATAL

Tomcat:解决Tomcat可以在eclipse启动,却无法显示默认页面的操作

解决Tomcat可以在eclipse启动,却无法显示默认页面的操作 今天在eclipse中配置好tomcat后访问不到它的主页,但是能运行自己的项目,一直找不到原因,百度之后最后解决了这个问题,总结如下: 原因在于eclipse是调用Tomcat的接口模拟tomcat而不是真正的启动它,因此显示不了Tomcat主页 解决办法如下: 一:双击控制台的Tomcat,如图所示: 二:修改以下两个地方: 三:若上图的单选框修改不了,如图所示: 那么最简单的解决办法就是:右击控制台的Tomcat选dele

how tomcat works 读书笔记四 tomcat的默认连接器

其实在第三章,就已经有了连接器的样子了,不过那只是一个学习工具,在这一章我们会开始分析tomcat4里面的默认连接器. 连接器 Tomcat连接器必须满足以下几个要求 1 实现org.apache.cataline.Connector接口 2 负责创建实现了org.apache.cataline.Request接口的request对象 3 负责创建实现了org.apache.cataline.Response接口的response对象 这里默认的连接器的原理很简单,就是等待http请求,创建re

eclipse中项目已经启动,可是tomcat一直显示在启动中

一.异常描述 1. 在eclipse中启动tomcat,应用已经启动成功,但是tomcat仍然一直处于starting装填 二.分析原因 1. 更换8080端口为9080,启动tomcat,可以完整启动.证明是8080端口问题: 2. 但是8080端口并没有被占用: 3. 在网上搜索可能原因,可能原因是打开了代理,导致端口被占用: http://www.cnblogs.com/winkey4986/p/3303412.html http://zhangzhaoaaa.iteye.com/blog

Tomcat专题二: JDK安装以及tomcat基本环境安装和使用

tomcat专题二:jdk安装以及tomcat基本安装和使用 书接tomcat专题一,在这一节将介绍一下java运行环境的安装以及tomcat的基本安装和使用.可能有人会问安装tomcat跟java运行环境有什么关系?正像专题一介绍的那样,tomcat本身只是一个业务框架,一个WEB容器,其底层还是基于jvm虚拟机来运行java程序的字节码文件.可以认为tomcat负责接受上层的应用请求,然后将请求的java程序交与jvm虚拟机执行并返回结果,这之间形成了一个调用关系,这在下面的tomcat启动