1.21张解析Tomcat运行原理与架构全貌💥通宵爆肝
2.从源码剖析SpringBoot中Tomcat的源码默认最大连接数
3.Tomcat源码分析— Bootstrap启动流程
4.源码详解系列(四) ------ DBCP2的使用和分析(包括JNDI和JTA支持)已停更
5.一文详解Tomcat Ghostcat-AJP协议文件读取/文件包含漏洞CVE-2020-1938
6.Tomcat 的工作原理万字总结,这回终于搞懂了!剖析
21张解析Tomcat运行原理与架构全貌💥通宵爆肝
早年间,源码小菜同学在Tomcat上通过继承HttpServlet进行CRUD操作,剖析后来引入Spring MVC框架的源码DispatcherServlet,使操作更加便捷。剖析jdk源码题库现今,源码随着Spring Boot框架的剖析内嵌,小菜能够更专注地进行CRUD操作,源码而无需过多关注服务器和框架的剖析细节。保持专一原则,源码小菜对服务器和框架始终保持谨慎态度。剖析 某日,源码小菜的剖析程序突然无法运行,面对困境,源码小菜并未选择“逃跑”,而是决定深入研究中间件的运行原理,通过层层解析,逐步揭开了Tomcat等中间件的核心设计。架构解析
Tomcat作为Java实现的Web服务器,是Java Web开发中流行的选择之一。本文作为解析Tomcat系列的第一篇,将带你深入探索Tomcat的运行流程,揭示其高效设计的核心组件。 处理网络请求是Web服务器的基础,Tomcat也不例外,从网络通信到业务处理,每个步骤都精心设计,以实现高效运行。连接器
处理网络通信的连接器是Tomcat的重要组成部分,它负责获取Socket、解析协议以及封装请求/响应等关键任务。具体实现包括EndPoint、Processor和ProtocolHandler。EndPoint
EndPoint负责点对点的通信,通过Socket处理网络通信。尽管在Tomcat 9中并未直接提供接口,而是通过抽象类实现,实际上提供了两种具体实现:用于不同IO模型的EndPoint。Processor
Processor组件负责解析协议,将网络流解析为Tomcat封装的请求和响应对象。通过不同的实现类,如AbstractProcessor、UpgradeProcessorBase,Tomcat能够支持HTTP、AJP等协议。ProtocolHandler
ProtocolHandler将动态变化的EndPoint和Processor组合起来,负责网络通信的Socket获取和流解析。虽然在设计上采用继承的方式,但实际应用中,源码为什么乘除只有四个组合实现。Adapter
Adapter组件作为适配器,将Processor解析得到的请求/响应转化为Servlet中定义的格式,便于后续容器的处理。虽然实现相对固定,但其作用至关重要。线程池
多路复用IO模型下,线程池用于管理监听任务和后续处理任务,确保高效执行。尽管EndPoint涉及线程池,但Tomcat实现的线程池并非JUC下的标准实现。多连接器
尽管Tomcat支持多个不同连接器的并行处理,但实际应用中通常使用默认配置,如HTTP、NIO和端口。增加连接器时,端口和协议将自动匹配处理。容器
容器层设计为多级父子结构,包括Engine、Host、Context和Wrapper,实现灵活扩展和高效管理。每个层次的容器通过标准实现和扩展实现,提供稳定的运行环境。Mapper
Mapper组件负责请求路由,解析HTTP请求并将其映射到相应的容器层。在多级容器中,Mapper组件通过map方法解析请求,简化了路由逻辑。PipeLine-Valve
为了实现灵活扩展,Tomcat使用PipeLine和Valve组件构建职责链模式,每层容器从First开始,到Basic结束,实现高效且可扩展的请求处理流程。其他组件
除了核心组件,Tomcat还提供类加载器、session管理器等辅助组件,用于维护Web服务器的正常运行。每个组件都精心设计,确保系统的稳定性和高效性。 在Tomcat的设计中,从连接器到容器,再到其他辅助组件,都体现了面向对象设计原则和现代软件架构的最佳实践,如职责链模式、观察者模式等,使得系统在复杂环境中保持高效稳定。 本文仅概要介绍了Tomcat的核心架构和主要组件,未来将深入源码分析,赛佰嘉源码全面解析Tomcat的运行原理。关注专栏,持续了解更多精彩内容。从源码剖析SpringBoot中Tomcat的默认最大连接数
虽然前端的Chrome浏览器对WebSocket连接有限制,但实际情况下这个限制并不常见。SpringBoot中Tomcat的默认最大连接数和线程数配置对请求处理能力有很大影响。在SpringBoot 1.5.9.RELEASE版本中,未配置时,Tomcat默认的最大连接数为,而最大线程数为。然而,随着版本更新,这些默认值在新版本(如2.2.3.BUILD-SNAPSHOT)中可能有所调整,具体配置需查看最新文档或源码。
在源码层面,可以通过ServerProperties类找到配置映射,然后在Tomcat类的customizeTomcat方法中,发现配置文件中的max-connections值会被赋值给endpoint的maxConnections属性,其默认值为。同样,maxThreads的默认值也在AbstractEndpoint类中设置,为。这些默认值在SpringBoot的最新版本中可能会有所变化,因此开发者在实际项目中需要根据需求进行调整。
Tomcat源码分析— Bootstrap启动流程
在探讨Tomcat启动流程之前,需要理解其组件及其周期状态,这为后续深入学习组件初始化与启动等提供了基础。
实现Lifecycle接口的组件拥有种状态。Bootstrap作为Tomcat启动入口类,负责构造类加载器以加载Catalina内部类,通过查找catalina.home目录下所有jar包,确保安全地加载应用程序类。
通过Bootstrap的main方法启动Tomcat实例,主要步骤包括创建Bootstrap对象、调用init方法,并根据启动参数执行load和start方法。
Bootstrap的init方法初始化类加载器,使得Tomcat能加载应用程序类,同时设置当前线程上下文加载器为CatalinaLoader。initClassLoaders方法创建三种类加载器,其中catalinaLoader与sharedLoader的父加载器为commonLoader。完成初始化后,预加载tomcat和javax包下的自定义类,避免访问权限异常。
调用catalinaLoader加载器加载Catalina类,通过反射实例化对象,并设置sharedLoader实例作为入参,最后将实例化的Catalina对象赋予catalinaDaemon成员变量。
Tomcat组件的金山开源源码初始化主要在load方法中完成,通过反射调用Catalina的load方法,构建并初始化StandardServer及其子组件。Bootstrap.load方法通过反射调用Catalina的load方法,Catalina的load方法实现序列图中的逻辑,初始化配置文件解析器Digester,构建standardServer实例,绑定当前catalina实例,设置根路径,并调用init方法完成初始化。
Tomcat中的容器或组件使用模板方法设计模式,子类通过重写LifecycleBase抽象类的模板方法initInternal实现初始化逻辑。LifecycleBase的init方法主要完成两件事:调用父类的LifecycleBase#init方法,由standerServer#initInternal方法执行实际初始化。init方法逻辑包括:执行LifecycleBase#initInternal抽象方法,由standardServer#initInternal方法完成初始化。
service组件的init方法主要初始化Connector连接器,连接器的初始化尤为重要。不同协议处理器如AjpAprProtocol、HttpNioProtocol的初始化流程将在后续文章中单独讲解。
Bootstrap类的main方法通过反射执行catalina实例的start方法,启动standardServer实例,使其监听端口并接收新请求。start方法主要逻辑包括启动Service、Engine容器、Executor执行器、MapperListener监听器、Connector连接器等组件。当启动成功后,创建并监听端口,Tomcat对外提供服务。
总结,Tomcat的启动流程清晰且依赖模板方法与责任链设计模式,理解这两种模式有助于更好地理解启动过程及代码。启动过程首先初始化各组件,如Server、Service、Engine容器、虚拟主机Host、上下文Context、Executor执行器、Connector连接器等,然后按顺序启动组件,成功后监听端口提供服务。
源码详解系列(四) ------ DBCP2的使用和分析(包括JNDI和JTA支持)已停更
DBCP是一个用于创建和管理数据库连接的工具,通过连接池复用连接以减少资源消耗。它具备连接数控制、连接有效性检测、连接泄露控制和缓存语句等功能。Tomcat内置连接池、综合类源码Spring团队推荐使用DBCP,阿里巴巴的druid也是基于DBCP开发的。 DBCP支持通过JNDI获取数据源,并且可以获取JTA或XA事务中的连接对象,用于两阶段提交(2PC)的事务处理。本篇文章将通过例子来解释如何使用DBCP。 以下是文章的详细内容:使用例子需求
本例将展示如何使用DBCP连接池获取连接对象,并进行基本的增删改查操作。工程环境
JDK:1.8.0_
maven:3.6.1
IDE:eclipse 4.
mysql-connector-java:8.0.
mysql:5.7.
DBCP:2.6.0
主要步骤
创建Maven项目,打包方式为war(war也可以是jar,这里选择war是为了测试JNDI功能)。
引入DBCP相关依赖。
在resources目录下创建dbcp.properties文件,配置数据库连接参数及连接池基本参数。
编写JDBCUtils类,实现初始化连接池、获取连接、管理事务和资源释放等功能。
创建测试类,实现基本的增删改查操作。
配置文件详解
dbcp.properties文件包含数据库连接参数和连接池基本参数,如数据库URL、用户名、密码、连接池大小等。其中,数据库URL后面添加了参数以避免乱码和时区问题。建议根据项目需求调整参数设置。基本连接属性
数据库URL
用户名
密码
连接池大小
缓存语句(在MySQL下建议关闭)
连接检查参数(建议开启testWhileIdle,避免性能影响)
事务相关参数(通常使用默认设置)
连接泄漏回收参数
其他参数(较少使用)
源码分析
DBCP主要涉及以下几个类:BasicDataSource:提供基本的数据库操作数据源。
BasicManagedDataSource:BasicDataSource的子类,用于创建支持XA事务或JTA事务的连接。
PoolingDataSource:BasicDataSource中实际调用的数据源,用于管理连接。
ManagedDataSource:PoolingDataSource的子类,用于支持XA事务或JTA事务的连接。
使用DBCP连接池创建连接时,首先创建BasicDataSource对象,初始化配置参数。然后从连接池中获取连接。连接获取过程涉及到数据源和连接池的创建,连接对象的包装和回收。通过JNDI获取数据源对象需求
使用JNDI获取DBCP数据源对象,以PerUserPoolDataSource和SharedPoolDataSource为例。为了在tomcat容器中测试,需要配置JNDI上下文。引入依赖
引入JNDI相关的依赖。
编写context.xml文件,配置JNDI上下文。
在web.xml中配置资源引用,将JNDI对象与web应用绑定。
测试结果
打包项目并部署到tomcat上运行,通过访问指定的jsp页面,验证JNDI获取数据源对象的正确性。使用DBCP测试两阶段提交
介绍如何使用DBCP实现JTA事务的两阶段提交(2PC)。使用DBCP的BasicManagedDataSource类支持事务处理。通过测试代码验证了2PC的正确性。 以上内容涵盖了DBCP的使用、配置、源码分析、JNDI集成以及两阶段提交的实现,为开发者提供了全面的参考。一文详解Tomcat Ghostcat-AJP协议文件读取/文件包含漏洞CVE--
文章首发于先知社区:xz.aliyun.com/t/
零基础慎入,因为一不小心你就看懂了。
以tomcat 8.5.版本为例进行漏洞分析,首先下载tomcat源码: http://archive.apache.org/dist/tomcat/tomcat-8/v8.5./src/apache-tomcat-8.5.-src.zip。搭建过程可以参考这篇Paper: Tomcat源码编译(IDEA)_Java_ww0peo的博客-CSDN博客。
通过浏览器访问 .0.0.1:会报错误。解决办法是IDEA中找到org.apache.catalina.startup.ContextConfig,增加如下的一行代码,将JSP解析器初始化。随后再次启动Tomcat,浏览器就能正常看到Tomcat的主页了。查看端口开放的开放情况,Tomcat运行开启了和端口。
Tomcat的Connector组件的主要职责就是负责接收客户端连接和客户端请求的处理加工。每个Connector会监听一个指定端口,分别负责对请求报文的解析和响应报文组装,解析过程封装Request对象,而组装过程封装Response对象。如果把Tomcat比作一个城堡,那么Connector组件就是城堡的城门,为进出城堡的人们提供通道。
Tomcat组件相关的配置文件是在conf/server.xml,配置文件中每一个元素都对应了Tomcat的一个组件。HTTP Connector很好理解,通过浏览器访问Tomcat服务器的Web应用时,使用的就是这个连接器;AJP Connector是通过AJP协议和一个Web容器进行交互。在将Tomcat与其他HTTP服务器(一般是Apache)集成时,就需要用到这个连接器。AJP协议是采用二进制形式代替文本形式传输,相比HTTP这种纯文本的协议来说,效率和性能更高,也做了很多优化。
浏览器只支持HTTP协议,并不能直接支持AJP协议。所以实际情况是,通过Apache的proxy_ajp模块进行反向代理,暴露成http协议(端口)给客户端访问。
Servlet意为服务程序,也可简单理解为是一种用来处理网络请求的一套规范。主要作用是给上级容器(Tomcat)提供doGet()和doPost()等方法,其生命周期实例化、初始化、调用、销毁受控于Tomcat容器。Tomcat中Servlet的配置是在conf/web.xml。所有请求进入tomcat,都会流经servlet。由注释可以很明显看出,如果没有匹配到任何应用指定的servlet,那么就会流到默认的servlet(即DefaultServlet ),而 JspServlet 负责处理所有JSP文件的请求。
Tomcat内部处理请求的流程第一次看可能觉得会有点复杂。理解了上文的基础,下面开始分析漏洞。这个漏洞主要是通过AJP协议(端口)触发。通过构造两个不同的请求,经过tomcat内部处理流程,一个走default servlet,另一个走 jsp servlet,可导致不同的漏洞:文件读取漏洞和文件包含漏洞。
文件读取漏洞走的是DefaultServlet,文件包含漏洞走的是JspServlet。下面开始逐一进行分析,测试使用的POC如下:YDHCUI/CNVD---Tomcat-Ajp-lfi。
文件读取漏洞中,通过构造AJP协议请求,我们可以读取到 WEB-INF/web.xml文件。关键点在于request对象中的三个参数:/WEB-INF/web.xml的路径被传入到getRelativePath()方法中,该方法会返回请求的资源路径。随后,通过validate()方法和normalize()方法进行参数校验,确保请求路径中不能包含"/../",从而限制只能读取webapps目录下的文件。
文件包含漏洞(可致RCE)与文件读取漏洞不同,请求经过AjpProcessor类的处理后,将请求转发给了JspServlet。通过构造特定的请求url,可以将任意文件包含到jsp页面中,造成远程代码执行的条件。关键点在于将请求url设置为特定格式,以触发Tomcat处理jsp文件的流程,进而执行包含的文件内容。
针对此漏洞,官方发布的9.0.版本的修复代码主要做了以下几点修复:强制AJP协议默认监听本地环回地址,而不是0.0.0.0;若使用AJP协议,设置secretRequired属性为true,强制配置secret来设置AJP协议认证凭证;配置属性白名单,若向AJP连接器发送任意未被识别的属性,都会响应错误。
总结:文章详细解析了Tomcat Ghostcat漏洞的原理、漏洞分析、修复方法,以及相关的基础知识,为读者提供了一次全面的学习体验。
Tomcat 的工作原理万字总结,这回终于搞懂了!
Tomcat 工作原理详解
理解Tomcat的工作原理对于深入掌握Web应用开发至关重要。当我们同时启动多个Tomcat实例,如何确定请求的处理者?以下是Tomcat处理HTTP请求的流程简要概括:用户发起请求到本地端口,Coyote连接器负责监听并接收请求。
连接器将请求传递给对应的Service Engine,Engine开始处理。
Engine根据请求路径(如localhost/test/index.jsp)匹配Host,这里是默认的localhost Host。
Host进一步查找与请求路径匹配的Context,比如/test。
Context根据URL模式找到对应的Servlet,如JspServlet处理.jsp文件。
构造请求和响应对象,调用Servlet的doGet或doPost方法执行业务逻辑。
响应对象逐级返回给Engine、Host、然后是Connector,最后送达浏览器。
尽管SpringBoot简化了许多部署工作,但理解Tomcat底层原理仍然是面试中不可忽视的部分。继续深入学习,不仅可以提升技术栈,也能在需要时进行性能调优和问题排查。 想了解更多关于Tomcat的配置和启动细节,可以查阅SpringBoot内嵌Tomcat的源码流程,以及在实际应用中的具体配置步骤。tomcat的基本原理tomcat简介
HELLO,tomcat的基本原理,tomcat简介很多人还不知道,现在让我们一起来看看吧!
1、中文名:汤姆猫外文名:Apache Tomcat性质:Java Web服务器最新版本:.0.Tomcat是Apache 软件基金会(Apache Software Foundation)的Jakarta 项目中的一个核心项目,由Apache、Sun 和其他一些公司及个人共同开发而成。
2、由于有了Sun 的参与和支持,最新的Servlet 和JSP 规范总是能在Tomcat 中得到体现,Tomcat 5支持最新的Servlet 2.4 和JSP 2.0 规范。
3、因为Tomcat 技术先进、性能稳定,而且免费,因而深受Java 爱好者的喜爱并得到了部分软件开发商的认可,成为比较流行的Web 应用服务器。
4、Tomcat 服务器是一个免费的开放源代码的Web 应用服务器,属于轻量级应用服务器,在中小型系统和并发访问用户不是很多的场合下被普遍使用,是开发和调试JSP 程序的首选。
5、对于一个初学者来说,可以这样认为,当在一台机器上配置好Apache 服务器,可利用它响应HTML(标准通用标记语言下的一个应用)页面的访问请求。
6、实际上Tomcat是Apache 服务器的扩展,但运行时它是独立运行的,所以当你运行tomcat 时,它实际上作为一个与Apache 独立的进程单独运行的。
7、诀窍是,当配置正确时,Apache 为HTML页面服务,而Tomcat 实际上运行JSP 页面和Servlet。
8、另外,Tomcat和IIS等Web服务器一样,具有处理HTML页面的功能,另外它还是一个Servlet和JSP容器,独立的Servlet容器是Tomcat的默认模式。
9、不过,Tomcat处理静态HTML的能力不如Apache服务器。
、Tomcat最新版本为.0.。
本文到此讲解完毕了,希望对大家有帮助。
tomcat是什么
Tomcat是一个开源的Web应用服务器。 Tomcat是由Apache软件基金会开发的,它是一个实现了Java Servlet规范、JavaServer Pages技术的Web应用服务器。其主要功能是提供一个能够响应HTTP协议的服务器环境,为Java Web应用程序提供运行和调试的环境。Tomcat被广泛用于开发和部署Java Web应用程序,尤其是基于Java EE标准的应用程序。它具备跨平台运行的能力,可在Windows、Linux、Unix等操作系统上运行。Tomcat的特点是简单易用,能快速集成和开发Web应用程序。由于其稳定性和可靠性,许多企业和开发者选择使用Tomcat作为他们的Web应用服务器。 以下是关于Tomcat的详细解释: 一、作为Web应用服务器:Tomcat提供了一个完整的HTTP协议实现,能够处理来自Web客户端的请求并返回响应。它允许开发者在其上部署Java Web应用程序,如Servlet、JSP等,从而实现对动态Web内容的支持。 二、支持Java EE规范:Tomcat遵循Java EE规范,支持诸如Servlet、JSP、EL、JSTL等技术。这使得开发者可以使用这些技术来构建功能丰富的Web应用程序。 三、开源和免费:Tomcat是一个开源项目,源代码公开且免费。开发者可以免费下载和使用Tomcat,并根据自己的需求进行定制和扩展。 四、跨平台性:Tomcat可以在多种操作系统上运行,如Windows、Linux、Unix等。这使得开发者可以在不同的平台上开发和部署Web应用程序,而无需担心平台兼容性问题。 总之,Tomcat是一个功能强大、稳定可靠的Web应用服务器,广泛应用于Java Web应用程序的开发和部署。由于其开源、免费和跨平台的特点,许多企业和开发者选择使用Tomcat来构建和部署他们的Web应用程序。