Tomcat8源码笔记(九)组件StandardContext启动流程--未完待续
StandardContext代表的是webapps下项目,一个项目就是一个StandardContext,作为Tomcat组件的一部分,就会实现Lifecycle接口,被Tomcat管理着生命周期,本文从StandardContext的启动记录。
StandardContext从被创建起,就是直接进入start方法,Tomcat中组件的start会检测是否初始化过,没有初始化不好意思回去初始化再来启动. StandardContext有着两个监听器,分别是ContextConfig以及MemoryLeakTracingListener,第一个是辅助监听器,第二个是出现内存泄露辅助监听器.
按照上面的ContextConfig可能针对的事件,StandardContext先初始化initInternal方法,然后是ContextConfig#init. StandardContext#initInternal,重要的是初始化了自身的线程池,以及JMX注册. 接下来查看ContextConfig#init.
ContextConfig#init:首先获取Digester类,之前在解析conf/server.xml时也是在Digester中处理的,所以这里下意识以为又要解析什么xml!contextConfig就是具体配置并开始解析的方法,解析的xml就是catalina-home/conf/content.xml,以前很少了解这个文件是干嘛的,下面有介绍这个文件conf/content.xml,解析完成conf/content.xml之后,实例化了webXmlParser为了解析web.xml文件!
catalina-home/conf/content.xml如下: 上面contentConfig方法就是用来解析该文件,有兴趣的可以再研究下,可以将断点打在Deigester的startElement、characters、endElement上;直接说结论,解析完之后StandardContext的watchResource就多了两个字符串的值,WEB-INF/web.xml,以及catalina-home/conf/web.xml,这个两个文件作用很明显项目部署就会根据这两个文件.
之后就到了StandardContext#start阶段,首先按照ContextConfig图分析的,会先执行ContextConfig#beforeStart. 分两步走,fixDocBase,antiLocking.
beforeStart第一步:代码片段位于ContextConfig#fixDocBase. 该方法是决定部署项目时候使用哪个项目,会根据server.xml中Host的unpackWars布尔值, 默认是true,比如webapps下存在ProjectA 以及ProjectA.war,那unpackWars为true就会动态的扩展该ProjectA,比较ProjectA和ProjectA.war的区别,具体实现是ExpandWar.expand.
beforeStart第二步,antiLocking,由于antiResourceLocking默认为false,所以相当于不作处理; antiResourceLocking如果是true,代表项目资源私有,他会悄悄在Tomcat catalina-home/temp目录下将你的项目复制一份,这样Tomcat运行时期你如果对原有项目修改不会生效,这样可能是为了防止热部署?
下一步到了StandardContext#startInternal,在这个方法中就部署了项目,代码量不包括方法调用就有了300+行;
Step1. postWorkDirectory()介绍
postWorkDirectory首先给每个StandardContext设置工作目录,比如ProjectA的工作目录就是catalina-home/work/Catalina/localhost/ProjectA,一个项目一个工作目录部署到catalina-home/work/Catalina/localhost下; 另外初始化了每个项目对应的ServletContext,采用ServletContext的实现ApplicationContext(和Spring的ApplicationContext重名),ApplicationContext相当于每个项目应用上下文吧(个人理解);
Step2.实例化WebResourceRoot实现类StandardRoot,并将StandardRoot和StandardContext关联起来(StandardContext的resource引用指向StandardRoot), StandardRoot#start ,
StandardRoot#startInternal就会处理/WEB-INF/lib下jar包等;
Step3.WebappLoader
实例化一个WebappLoader,单独用来加载每一个项目,将webappLoader和StandardContext关联起来(StandardContext的loader指向webappLoader). WebappLoader#start,初始化每一个项目的AppLoader,具体类型是WebappClassLoader; 并且获取到每个项目的classPath; 之后将WebappClassLoader绑定到Thread.currentThread上;
Step4. ContextConfig#configureStart
代码手动触发ContextConfig的configureStart方法,该方法就可以看成Web项目的入口, 其中webConfig方法介绍下,该方法解析了Web.xml,并且调用processServletContainerInitializers()来解析实现了ServletContainerInitializer的类(Servlet3.0之后的特性);webConfig方法并且将每个JSP实例化成StandardWrapper加入到StandardContext中,由于代码量太大 并且不是专门研究JSP,所以ContextConfig关于configureStart的研究告一段落;
Tomcat StandardContext启动中有太多值得思量的地方,jar包的加载、类加载器的设置、资源lib/classes的处理,这些暂时还没有能力分析有些遗憾,以后有机会再钻研!
这里梳理下一些常见的组件的启动流程,从StandardService开始,第一步是StandardEngine#start, StandardEngine#start又调用StandardHost#start, StandardHost启动成功之前,调用HostConfig#start,负责部署解析webapps下的项目; 之后StandardHost启动成功,StandardEngine也启动成功,然后就可使StandardService的另一个模板的启动,Connector!
Tomcat8源码笔记(九)组件StandardContext启动流程--未完待续的更多相关文章
- Tomcat8源码笔记(七)组件启动Server Service Engine Host启动
一.Tomcat启动的入口 Tomcat初始化简单流程前面博客介绍了一遍,组件除了StandardHost都有博客,欢迎大家指文中错误.Tomcat启动类是Bootstrap,而启动容器启动入口位于 ...
- Tomcat8源码笔记(五)组件Container分析
Tomcat8源码笔记(四)Server和Service初始化 介绍过Tomcat中Service的初始化 最先初始化就是Container,而Container初始化过程是咋样的? 说到Contai ...
- Tomcat8源码笔记(八)明白Tomcat怎么部署webapps下项目
以前没想过这么个问题:Tomcat怎么处理webapps下项目,并且我访问浏览器ip: port/项目名/请求路径,以SSM为例,Tomcat怎么就能将请求找到项目呢,项目还是个文件夹类型的? Tom ...
- Tomcat8源码笔记(六)连接器Connector分析
根据 Tomcat8源码笔记(五)组件Container分析 前文分析,StandardService的初始化重心由 StandardEngine转移到了Connector的初始化,本篇记录下Conn ...
- Tomcat8源码笔记(三)Catalina加载过程
之前介绍过 Catalina加载过程是Bootstrap的load调用的 Tomcat8源码笔记(二)Bootstrap启动 按照Catalina的load过程,大致如下: 接下来一步步分析加载过程 ...
- Tomcat8源码笔记(四)Server和Service初始化
上一章 简单说明下Tomcat各个组件: Server:服务器,Tomcat服务器,一个Tomcat只有一个Server组件; Service:业务层,是Server下最大的子容器,一个Server可 ...
- Flink 源码解析 —— Standalone Session Cluster 启动流程深度分析之 Job Manager 启动
Job Manager 启动 https://t.zsxq.com/AurR3rN 博客 1.Flink 从0到1学习 -- Apache Flink 介绍 2.Flink 从0到1学习 -- Mac ...
- Flink 源码解析 —— Standalone session 模式启动流程
Standalone session 模式启动流程 https://t.zsxq.com/EemAEIi 博客 1.Flink 从0到1学习 -- Apache Flink 介绍 2.Flink 从0 ...
- Flink 源码解析 —— Standalone Session Cluster 启动流程深度分析之 Task Manager 启动
Task Manager 启动 https://t.zsxq.com/qjEUFau 博客 1.Flink 从0到1学习 -- Apache Flink 介绍 2.Flink 从0到1学习 -- Ma ...
随机推荐
- CPU芯片哪家强?电视处理器这么选就对了!
任何智能设备,CPU(Central Processing Unit/中央处理器)都是决定其性能优劣的核心组件,在家电界,最为人们熟知的CPU厂商就是Mstar以及Amlogic这两个品牌了,那两个品 ...
- suse11 安装 python3.6 python3 安装步骤
首先需要去网上下载Python-3.6.4.tgz,libopenssl-devel-0.9.8j-2.1.x86_64.rpm zlib-devel-1.2.7-3.14.x86_64.rpm li ...
- PowerShell工作流学习-7-编写脚本工作流帮助
关键点: a)工作流中不支持基于注释的帮助(标识工作流的帮助文件的 .ExternalHelp 注释除外). b)支持get-help参数的方式:使用 .ExternalHelp 注释以便 Get-H ...
- redis_列表对象
<Redis设计与实现>中说:redis列表对象有两种底层编码格式:ziplist.linkedlist,其中ziplist用压缩列表实现.linkedlist用双向链表实现 但我在实践中 ...
- Catalog
Java SE EE| Hibernate | Struts2Spring/SpringMVC | MyBatis C# Python PHP C/C++ | STL 汇编语言 ...
- 画PCB之电流与线宽的关系
来源:(多图) 超强整理!PCB设计之电流与线宽的关系http://www.51hei.com/bbs/dpj-39134-1.html 关于PCB线宽和电流的经验公式,关系表和软件网上都很多,本文把 ...
- git忽视修改的文件
对于tracked文件来说,使用.gitignore是不行的.但是git提供了新的方法. 使用命令 git update-index --assume-unchanged <files>, ...
- gii配置
下载完成后不要设置urlManager http://zjm.testyii.com/index.php?r=gii 即可进入gii页面 或者是 将'urlManager'=> [ 'enabl ...
- Android中监控home键
一.需求 在应用开发过程中,启动服务开启线程锁等待服务返回解锁,为了避免点击home键使线程锁卡死的bug,需要监控home键,解锁线程. 二.实现 在应用时,需要register和unregiste ...
- windows10的环境变量path如何列表显示
如果你的变量值以%开头,打开编辑的时候就会显示一串的变量值,不方便查找编辑 所以将变量值更改为以盘符开始,就可以解决这个问题,比如:D:\WorkSoft\app\product\11.2.0\dbh ...