tomcat服务器启动时序图

简介: tomcat服务器启动时序图

Tomcat服务器启动时序图


image.png

Tomcat中最顶层的容器叫Server,代表整个服务器,Server中包含至少一个Service,用于具体提供服务。


Service主要包含两部分:Connector和Container。Connector用于处理连接相关的事情,并提供Socket与Request、response的转换,Container用于封装和管理Servlet,以及具体处理request请求。


一个Tomcat中只有一个Server,一个Server可以包含多个Service,一个Service包含一个Container和多个Connector(因为一个服务可以有多个连接,如同时提供HTTP和HTTPS连接,也可以提供相同协议不同端口的连接)


Tomcat里的Server有org.apache.catalina.startup.Catalina来管理,Catalina是整个Tomcat管理类,它里面有三个方法:load、start、stop分别管理整个服务器的生命周期,load方法用于根据conf/server.xml文件创建Server并调用Server的init方法进行初始化,start方法用于启动服务器,stop方法用于停止服务器,start和stop方法在内部分别调用了Server的start方法和stop方法,load方法内部调用了Server的init方法,这个三个方法都会按容器的结构逐层调用相应的方法,这样整服务器就启动了。


Bootstrap的启动过程

Tomcat的入口在org.apache.catalina.startup.Bootstrap中。正常情况下启动Tomcat就是调用的Bootstrap的main方法。


main方法中:首先新建了Bootstrap,并执行init方法初始化;然后处理main方法传入的命令,如果arg参数为空,默认执行start。在init方法中初始化了ClassLoader,并用ClassLoader创建了Catalina实例,然后赋给catalinaDaemon变量,后面的执行操作有catalinaDaemon执行。


对start命令的处理调用了三个方法:setAwait(true)、load(args)和start()。

Catalina的启动过程

Catalina的启动主要调用setAwait(true)、load和start方法完成,setAwait方法用于设置Server启动完成后是否进入等待状态的标志,如果为true则进入,否则不进入;load方法用于加载配置文件,创建并初始化Server;start方法用于启动服务器。


Catalina的load方法根据conf/server.xml创建了Server对象,并赋值给server属性(具体解析操作时通过开源项目Digester完成),然后调用了server的init方法。


Server的启动过程

Server接口中提供addService(Service service)、removeService(Service service)来添加和删除Service,Server的init方法和start方法分别循环调用了每个Service的init方法和start方法来启动所有Service。


Server的默认实现是org.apache.catalina.core.StandardServer,StandardServer继承自LifecycleMBeanBase,LifecycleMBeanBase又继承LifecycleBase,init和start方法就定义在了LifecycleBase中,LifecycleBase里的init方法和start方法又调用initInternal方法和startInternal方法,这两个方法都是模板方法,由子类具体实现,所以调用StandardServer的init和start方法时会执行StandardServer自己的initInternal方法和startInternal方法,这就是Tomcat生命周期的管理方式


Service的启动过程

Service的默认实现是org.apache.catalina.core.StandardService也继承自LifecycleMBeanBase类,所有init方法和start方法最终也会调用initInternal方法和startInternal方法,


StandardService中的initInternal方法和startInternal方法主要调用container、executors、mapperListener、connectors的init方法和start方法。mapperListener是Mapper的监听器,用于监听container容器的变化,executors是用在connectors中管理线程的线程池,在server.xml配置文件中有参考用法,默认注释

<Service name="Catalina"><!--The connectors can use a shared executor, you can define one or more named thread pools--><!--<Executor name="tomcatThreadPool" namePrefix="catalina-exec-"        maxThreads="150" minSpareThreads="4"/>--><!-- A "Connector" represents an endpoint by which requests are received
and responses are returned. Documentation at :         Java HTTP Connector:/docs/config/http.html         Java AJP  Connector:/docs/config/ajp.html         APR (HTTP/AJP) Connector:/docs/apr.html         Define a non-SSL/TLS HTTP/1.1 Connector on port 8080--><Connector port="8080" protocol="HTTP/1.1"               connectionTimeout="20000"               redirectPort="8443"/><!-- A "Connector" using the shared thread pool--><!--<Connector executor="tomcatThreadPool"               port="8080" protocol="HTTP/1.1"               connectionTimeout="20000"               redirectPort="8443"/>-->


maxThreads:最多同时启动150个线程池

minSpareThreads:最少要有4个可用线程


目录
相关文章
|
3月前
|
Java 应用服务中间件 Windows
windows服务器重装系统之后,Tomcat服务如何恢复?
windows服务器重装系统之后,Tomcat服务如何恢复?
65 10
|
2月前
|
安全 Java 应用服务中间件
【服务器知识】Tomcat简单入门
【服务器知识】Tomcat简单入门
|
4月前
|
应用服务中间件 Docker 容器
在服务器中使用Docker安装Tomcat、同时实现目录挂载、并且部署War包到服务器
这篇文章介绍了在Docker中安装Tomcat的过程,包括搜索Tomcat镜像、拉取镜像、目录挂载的准备、创建并挂载容器,以及如何进入容器和进行测试。文中还说明了如何将WAR包部署到Tomcat服务器并访问部署的应用。
在服务器中使用Docker安装Tomcat、同时实现目录挂载、并且部署War包到服务器
|
4月前
|
网络协议 Java 应用服务中间件
Tomcat源码分析 (一)----- 手撕Java Web服务器需要准备哪些工作
本文探讨了后端开发中Web服务器的重要性,特别是Tomcat框架的地位与作用。通过解析Tomcat的内部机制,文章引导读者理解其复杂性,并提出了一种实践方式——手工构建简易Web服务器,以此加深对Web服务器运作原理的认识。文章还详细介绍了HTTP协议的工作流程,包括请求与响应的具体格式,并通过Socket编程在Java中的应用实例,展示了客户端与服务器间的数据交换过程。最后,通过一个简单的Java Web服务器实现案例,说明了如何处理HTTP请求及响应,强调虽然构建基本的Web服务器相对直接,但诸如Tomcat这样的成熟框架提供了更为丰富和必要的功能。
|
4月前
|
Java 应用服务中间件 Apache
在 Debian 服务器上安装和配置 Apache Tomcat 的方法
在 Debian 服务器上安装和配置 Apache Tomcat 的方法
75 0
|
6月前
|
Java 关系型数据库 MySQL
杨校老师课堂之Java项目部署到云端服务器之安装MySQL、Jdk、Tomcat
杨校老师课堂之Java项目部署到云端服务器之安装MySQL、Jdk、Tomcat
65 0
杨校老师课堂之Java项目部署到云端服务器之安装MySQL、Jdk、Tomcat
|
6月前
|
Java 应用服务中间件 程序员
JavaWeb基础第四章(SpringBootWeb工程,HTTP协议与Web服务器-Tomcat)
JavaWeb基础第四章(SpringBootWeb工程,HTTP协议与Web服务器-Tomcat)
|
弹性计算 Linux 应用服务中间件
【阿里云ECS】外网无法访问tomcat下部署的项目
问题提出:在ESC实例上部署了jdk和tomcat,启动tomct后,内网可以访问8080端口,外网无法访问8080. 系统环境:Linux version 3.10.0-693.2.2.el7.x86_64 (builder@kbuilder.dev.centos.org) (gcc version 4.8.5 20150623 (Red Hat 4.8.5-16) (GCC) )  解决方案: 在网上查资料后说是配置安全组策咯,但是没说是在ESC上部署,还是在阿里云网站上部署,这是一个大坑。
3817 0
|
4天前
|
弹性计算 运维 安全
阿里云轻量应用服务器与ECS的区别及选择指南
轻量应用服务器和云服务器ECS(Elastic Compute Service)是两款颇受欢迎的产品。本文将对这两者进行详细的对比,帮助用户更好地理解它们之间的区别,并根据自身需求做出明智的选择。
|
5天前
|
SQL 弹性计算 安全
阿里云上云优选与飞天加速计划活动区别及购买云服务器后续必做功课参考
对于很多用户来说,购买云服务器通常都是通过阿里云当下的各种活动来购买,这就有必要了解这些活动的区别,同时由于活动内的云服务器购买之后还需要单独购买并挂载数据盘,还需要设置远程密码以及安全组等操作之后才能正常使用云服务器。本文就为大家介绍一下目前比较热门的上云优选与飞天加速计划两个活动的区别,以及通过活动来购买云服务器之后的一些必做功课,确保云服务器可以正常使用,以供参考。
下一篇
DataWorks