导读:tomcat是一个开源的web服务器,它实现了我们常用的Servlet,JSP,EL等相关规范,因为其性能稳定,开源等因素得到越来越多开发者的青睐,出于学习的目的,我决定研读其源码,并将阶段性成果同步出来与大家探讨。
关键词:tomcat,web服务器
以命令行启动方式为例,结合文字说明和流程图讲述一下tomcat启动过程概览。
启动过程文字描述执行startup.bat或者startup.sh
startup.bat触发catalina.bat
catalina.bat执行org.apache.catalina.startup.Bootstrap的main方法
Bootstrap.init()
初始化类加载器
通过反射加载启动类,Bootstrap只是一个引导程序,真正的启动类是org.apache.catalina.startup.Catalina
Bootstrap执行启动逻辑
Catalina.setAwait
Catalina.load,该方法会通过解析conf/server.xml下的配置,初始化Server对象
initDirs,初始化一个临时目录
initNaming,设置命名服务相关的几个环境变量
createStartDigester,创建一个Digester用来解析server.xml,解析过程中会完成Server的装配工作,Digester原理可以参考
加载server.xml并使用Digester解析,解析完成意味着Catalina下的server对象被初始化完成
将System.out和System.err重定向到ystemLogHandler类
server.init,其init会逐层触发子元素的init方法,server.init->service.init->engine/connector.init等等
Catalina.start,调用server.start
启动NamingContext并将所有JNDI引用绑定到其中
逐层触发子元素的start方法server.start->service.start->engine/connector.start等等
StandardHost.start(StandardHost作为Engine的child,由engine触发其start方法)
将ErrorReportValve添加到pipeline中
配置StandardHostValve
启动HostConfig组件,这一步并不是显示调用,而是使用了事件机制,HostConfig监听lifecycleEvent事件
收到Lifecycle.START_EVENT事件时开始deployApps
(以webapps这种方式部署应用为例)扫描webapps下目录,解析目录文件,将其封装为StandardContext对象
StandardContext.start
StandardContext.start执行完成会通过事件机制触发ContextConfig.configureStart,confiureStart通过解析StandardContext关联的目录完成web工程的部署,包括解析Servlet,Filter配置等,将配置元信息添加到StandContext内部
启动流程图花了一点时间(其实挺烧脑的)制作了几张Tomat启动时的流程图,方法粒度由小到大,贴出来希望可以帮到刚入门tomcat学习的我们。
一级调用
二级调用
三级调用
四级调用
。。。省略5-N-1级,需要的可以私聊我
终极
写在最后
通过最后一张流程图相信你也意识到了tomcat启动其实是一个比较复杂的过程,我博客中描述的只是一个极其缩略的版本,后续计划是将大流程逐步分解为单篇博客可以讲清楚的子流程写出来。
如果觉得有用,请您点个推荐。 参考资料https://tomcat.apache.org/tomcat-8.5-doc/architecture/index.html