TOMCAT源码调试入口是Bootstrap类的main方法,我的启动参数VM:

-Dcatalina.home=E:/Tomcat_Source_Code/apache-tomcat-8.0.53-src/catalina-home
-Dcatalina.base=E:/Tomcat_Source_Code/apache-tomcat-8.0.53-src/catalina-home
-Djava.endorsed.dirs=E:/Tomcat_Source_Code/apache-tomcat-8.0.53-src/catalina-home/endorsed
-Djava.io.tmpdir=E:/Tomcat_Source_Code/apache-tomcat-8.0.53-src/catalina-home/temp
-Djava.util.logging.manager=org.apache.juli.ClassLoaderLogManager
-Djava.util.logging.config.file=E:/Tomcat_Source_Code/apache-tomcat-8.0.53-src/catalina-home/conf/logging.properties

Bootstrap执行main方法之前,先来看下static静态代码块做了哪些:

从当前系统变量、VM参数中获取 catalina.home作为 Bootstrap的 catalinaHomeFile,从系统变量、VM参数中获取catalina.base作为Bootstrap的catalinaBaseFile , 一般catalina.home和catalina.base 都指向同一个目录

main方法作为Bootstrap的入口,做了以下几个操作:实例化一个Bootstrap,并且调用Bootstrap的init,将Bootstrap实例赋给daemon属性;Bootstrap实例分别调用setAwait(true)、load、start方法;

Bootstrap实例初始化

简单描述下Boostrap初始化完成工作: 初始化类加载器、实例化Catalina、反射调用Catalina实例setParentClassLoader、Bootstrap持有Catalina实例。

一.初始化类加载器

这是Tomcat8.0官网中对ClassLoader的描述 Tomcat ClassLoader官网 ,Common就是此处的commonLoader, 至于下面还有两个 catalinaLoader 以及sharedLoader,为什么在8.0的源码中还存在呢?历史遗留问题,在Tomcat6.0以前的版本,类加载器结构是这样的 Tomcat5.5官网 。 所以在Tomcat6.0后仍然保留catalinaLoader、sharedLoader,只不过会发现他们指向commonLoader而已。

创建commonLoader类加载器

CatalinaProperties类静态代码块按照一下顺序尝试加载properties文件:从环境变量中读取catalina.config 、 或者catalina-home/conf/catalina.properties、或包org/apache/catalina/startup下catalina.properties,读取key-value并且通过System.setProperty保存在内存中,默认catalina-home/conf/catalina.properties文件中common.loader内容如下

common.loader="${catalina.base}/lib","${catalina.base}/lib/*.jar","${catalina.home}/lib","${catalina.home}/lib/*.jar"

使用replace方法将${catalina.base}替换成之前系统变量、VM参数中读取的catalina.base,将${catalina.home}替换成读取到的catalina.home;

getPaths方法再讲上面拆分成字符数组,catalina.home/lib  、catalina.home/lib/*.jar ,因为catalina.home和catalina.base是一样的;

将上面得到路径实例化成Repository,仓库的意思,比如catalina.home/lib 就是RepositoryType.DIR目录类型仓库,catalina.home/lib/*.jar就是RepositoryType.GLOB全局类型仓库,

利用仓库实例化URLClassLoader,比如DIR目录类型的仓库,校验catalina.home/lib是否存在、是否可读、是不是目录,之后通过file://路径构件URL统一资源定位符;比如GLOB类型仓库,遍历

catalina.home/lib下所有jar,每一个jar文件构造一个URL,最后得到new URLClassLoader(URL[] urls).

总结commonLoader:就是加载catalina.home下lib包中所有jar文件,而catalinaLoader、sharedLoader在Tomca6.0就都指向commonLoader了!

二.Catalina实例化

setSecurityProtection方法给Catalina的package.definition以及package.access属性赋值,这两个包定义、包访问属性来自于catalina.home/conf/catalina.propreties

实例化完成之后,通过反射调用Catalina的setParentClassLoader方法,参数为sharedLoader,沿用了Tomcat6.0之前,但是Tomcat6之后取消了sharedLoader以及catalinaLoader, 都是CommonLoader.  接着让Bootstrap关联Catalina实例,放在Bootstrap实例daemon的catalinaDaemon属性里。

Bootstrap加载、启动

Bootstrap实例加载之前,会调用setAwait方法, 上面Boostrap实例daemon持有catalinaDaemon,这里通过反射调用catalinaDaemon的setAwait为true,目的是为了让Tomcat程序处于运行状态,接收HTTP请求,一旦设置为false,Tomcat容器只是启动运行一遍就停止,所以说这一步不得不设置标志位!

Bootstrap加载load

bootstrap实例daemon只是作为一个辅助启动类,load方法也是如此,通过反射调用catalinaDaemon的load方法。Catalina实例的load篇幅比较长,下一篇博文记录。

Bootstrap启动start

Bootstrap作为辅助类,可以说相当尽心尽力了,启动Tomcat也是通过反射交给Catalina实例的start方法来完成。

总结

Tomcat的加载配置文件、启动过程都不是在Bootstrap中完成,都是通过Bootstrap反射调用Catalina实例的load、start方法,来完成Tomcat容器的启动。

而我觉得Bootstrap到这一步最大的作用,在于实例化commonLoader,通过加载catalina.properties文件中的的common.loader;创建了一个CommonLoader,赋给Catalina作为parentClassLoader。

Tomcat8源码笔记(二)Bootstrap启动的更多相关文章

  1. Tomcat8源码笔记(七)组件启动Server Service Engine Host启动

    一.Tomcat启动的入口 Tomcat初始化简单流程前面博客介绍了一遍,组件除了StandardHost都有博客,欢迎大家指文中错误.Tomcat启动类是Bootstrap,而启动容器启动入口位于 ...

  2. Tomcat8源码笔记(三)Catalina加载过程

    之前介绍过 Catalina加载过程是Bootstrap的load调用的  Tomcat8源码笔记(二)Bootstrap启动 按照Catalina的load过程,大致如下: 接下来一步步分析加载过程 ...

  3. Tomcat8源码笔记(八)明白Tomcat怎么部署webapps下项目

    以前没想过这么个问题:Tomcat怎么处理webapps下项目,并且我访问浏览器ip: port/项目名/请求路径,以SSM为例,Tomcat怎么就能将请求找到项目呢,项目还是个文件夹类型的? Tom ...

  4. Tomcat8源码笔记(六)连接器Connector分析

    根据 Tomcat8源码笔记(五)组件Container分析 前文分析,StandardService的初始化重心由 StandardEngine转移到了Connector的初始化,本篇记录下Conn ...

  5. Tomcat8源码笔记(五)组件Container分析

    Tomcat8源码笔记(四)Server和Service初始化 介绍过Tomcat中Service的初始化 最先初始化就是Container,而Container初始化过程是咋样的? 说到Contai ...

  6. Tomcat8源码笔记(四)Server和Service初始化

    上一章 简单说明下Tomcat各个组件: Server:服务器,Tomcat服务器,一个Tomcat只有一个Server组件; Service:业务层,是Server下最大的子容器,一个Server可 ...

  7. Tomcat8源码笔记(一)Lifecycle接口

    第一次阅读Tomcat8源码,就以Lifecycle作为笔记阅读的开篇吧,一千个读者就有一千个哈姆雷特,每个人都Tomcat的理解都不同,如果不记录一次Tomcat源码可能忘了就忘了. 断断DEBUG ...

  8. jQuery源码笔记(二):定义了一些变量和函数 jQuery = function(){}

    笔记(二)也分为三部分: 一. 介绍: 注释说明:v2.0.3版本.Sizzle选择器.MIT软件许可注释中的#的信息索引.查询地址(英文版)匿名函数自执行:window参数及undefined参数意 ...

  9. tomcat8 源码分析 | 组件及启动过程

    tomcat 8 源码分析 ,本文主要讲解tomcat拥有哪些组件,容器,又是如何启动的 推荐访问我的个人网站,排版更好看呦: https://chenmingyu.top/tomcat-source ...

随机推荐

  1. 选择困难症的福音——团队Scrum冲刺阶段-Day 1领航

    选择困难症的福音--团队Scrum冲刺阶段-Day 1领航 各个成员在 Alpha 阶段认领的任务 小组成员 分工 任务量 严域俊 完成小游戏接口部分.小游戏编写部分 21 吴恒佚 决策判断部分.小游 ...

  2. AJAX html 传输json字符串&&巧妙运用eval()来解析返回的JSON字符串

    1.AJAX html 传输json字符串: js方法如下: function saveRetYwlsh(){ var xmbh = document.getElementById("xmb ...

  3. 关于CSS布局

    是时候单独列出一篇文章记录CSS布局了. http://www.imooc.com/article/2235  [史上最全Html和CSS布局技巧]

  4. ZOJ 3229 Shoot the Bullet (有源有汇有上下界最大流)

    题意:一个人要给女孩子们拍照,一共 n 天,m 个女孩子,每天他至多拍 d[i] 张照片,每个女孩子总共要被至少拍 g[i] 次.在第 i 天,可以拍 c[i] 个女孩子,c[i] 个女孩子中每个女孩 ...

  5. 2017-2018-1 20155205 嵌入式C语言——时钟

    2017-2018-1 20155205 嵌入式C语言--时钟 题目要求 基础知识 插入位(以分钟为例) 提取位(以分钟为例) 在提取分钟时,运用到了位运算,位运算有以下规律: &0 --&g ...

  6. PHP几种加密方式

    1.MD5() 2.Sha1() 3.urlencode()方法用于加密,urldecode()方法用于解密 4.base64_encode (  )  64位加密   base64_decode ( ...

  7. Django Template 进阶

    回顾: Variables {{ var }} {{ dict.key }} {{ var.attr }} {{ var.method }} {{ varindex }} Filter {{ list ...

  8. 2018/7/26号碰到了个奇怪的问题(http有问题,但是ftp没毛病)

    过程大概是这样的 本来测试服务器中发ajax没问题,突然暴毙了,服务器又通过ajax发了另外一个请求(与之前不一样). nginx  reload 没毛病  ,ftp 也使用正常. 出了什么问题呢?  ...

  9. ReactNative 深拷贝

    1: 导入 import _ from 'lodash' 2: _.cloneDeep(obj)

  10. Spring AOP术语:连接点和切点的区别。

    定义: 1.连接点(Join point):连接点是在应用执行过程中能够插入切面(Aspect)的一个点.这些点可以是调用方法时.甚至修改一个字段时. 2.切点(Pointcut):切点是指通知(Ad ...