【面试】tomcat类加载机制

news2025/1/10 21:54:49

目录

          • 1. 说明
          • 2. 主要类加载器
            • 2.1 Bootstrap类加载器
            • 2.2 Common类加载器
            • 2.3 Catalina类加载器
            • 2.4 Shared类加载器
            • 2.5 Web应用类加载器
            • 2.5 JSP类加载器
          • 3. 图示
          • 4. 特点
          • 5. 加载顺序
          • 6. 面试题

1. 说明
  • 1.tomcat的类加载机制是违反了双亲委派原则的,对于一些未加载的非基础类,各个web应用自己的类加载器(WebAppClassLoader)会优先查看自己的仓库加载,加载不到时再交给CommonClassLoader走双亲委派。
  • 2.双亲委派模型要求除了顶层的启动类加载器之外,其余的类加载器都应当由自己的父类加载器加载。
  • 3.tomcat为了实现隔离性,没有遵守双亲委派模型,每个WebAppClassLoader加载自己的目录下的class文件,不会传递给父类加载器。
2. 主要类加载器
2.1 Bootstrap类加载器
  • 1.负责加载JVM启动所需的类,以及Tomcat自身的核心类,如Catalina和Coyote等。
  • 2.这些类位于JVM的核心类库中,如%JAVA_HOME%/jre/lib目录。
2.2 Common类加载器
  • 1.作为Tomcat的通用类加载器,负责加载Tomcat使用以及Web应用通用的一些类,这些类位于$CATALINA_HOME/lib目录下,如servlet-api.jar等。
  • 2.Common类加载器是所有Web应用共享的,其加载的类对所有Web应用都可见。
2.3 Catalina类加载器
  • 1.专门用于加载Tomcat内部使用的类,如Servlet容器、生命周期监听器等。
  • 2.这些类对于Web应用是不可见的,以确保Tomcat内部组件的封装性和独立性。
  • 3.Catalina类加载器以Common类加载器为父加载器。
2.4 Shared类加载器
  • 1.负责加载Tomcat的共享库目录(如$CATALINA_HOME/shared/lib)下的类文件。
  • 2.这些类对于所有的Web应用程序都是可见的,但与Common类加载器加载的类不同,Shared类加载器加载的类更侧重于Web应用之间的共享资源。
  • 3.Shared类加载器同样以Common类加载器为父加载器。
2.5 Web应用类加载器
  • 1.WebAppClassLoader。
  • 2.每个Web应用程序都有一个独立的类加载器,即Web应用类加载器。
  • 3.它负责加载Web应用程序目录下的类文件和库文件(位于/WEB-INF/classes和/WEB-INF/lib目录下)。
  • 4.这些类加载器之间是相互隔离的,确保了不同Web应用程序之间的类隔离和资源隔离。
2.5 JSP类加载器
  • 1.JasperLoader。
  • 2.这个类加载器是Tomcat特有的,用于处理JSP文件的编译和加载过程。
  • 3.JSP文件在Tomcat中实际上会被编译成Servlet类,然后再由Servlet容器来执行。这个编译和加载的过程就是由JSP类加载器来完成的。
  • 4.每个JSP文件在Tomcat中都会对应一个唯一的JSP类加载器,这样做的主要目的是为了支持JSP文件的热部署和热替换功能。
  • 5.当JSP文件被修改后,Tomcat能够检测到这种变化,并自动卸载旧的JSP类加载器,然后重新创建一个新的JSP类加载器来加载修改后的JSP文件。
  • 6.用户就可以在不重启Tomcat服务器的情况下,看到JSP页面的更新内容,提高了开发和部署的效率。
3. 图示
4. 特点
  • 1.类隔离:通过为每个Web应用程序分配独立的类加载器,Tomcat实现了不同Web应用程序之间的类隔离。这有助于避免类库冲突和依赖问题。
  • 2.灵活性:由于Web应用类加载器是独立的,因此可以针对单个Web应用进行重新部署,而不会影响到其他Web应用。这提高了部署的灵活性和应用的可用性。
  • 3.性能优化:由于每个Web应用都有自己的类加载器,Tomcat在加载类时不会搜索其他Web应用包含的Jar包,从而提高了类加载的性能。
  • 4.违反双亲委派模型:Tomcat的类加载机制在一定程度上违反了Java的双亲委派模型。在某些情况下,Web应用类加载器会优先尝试加载类,而不是先委派给父类加载器。这是为了优先加载Web应用自己定义的类,以满足特定的需求。然而,这也带来了一定的风险,如类库冲突和安全问题。因此,在设计和使用Tomcat时,需要谨慎处理这些潜在的问题。
5. 加载顺序
  • 1.使用bootstrap引导类加载器加载,加载JVM运行基本的类,以及标准扩展类(jre/lib/ext中的类)。
  • 2.使用system系统类加载器加载,加载Catalina.bat中指定位置的类。
  • 3.使用应用类加载器在WEB-INF/classes中加载。
  • 4.使用应用类加载器在WEB-INF/lib中加载。
  • 5.使用common类加载器在CATALINA_HOME/lib中加载,加载tomcat以及应用通用的类,位于CATALINA/lib下。
6. 面试题
  • 1.tomcat不遵循双亲委派机制,如果自己定义一个恶意的HashMap,会不会有风险?
tomcat不遵循双亲委派机制,只是自定义的classloader顺序不同,但顶层还是相同的,
还是要去顶层请求classloader。
  • 2.tomcat是个web容器,它解决了什么问题?
1.一个web容器可能需要部署两个应用程序,不同的应用程序可能会依赖同一个第三方类库的不同版本,不能要求同一个类库
在同一个服务器只有一份,因此要保证每个应用程序的类库都是独立的,保证相互隔离。
2.部署在同一个web容器中相同的类库相同的版本可以共享。
3.web容器也有自己依赖的类库,不能与应用程序的类库混淆。基于安全考虑,让容器的类库和程序的类库隔离开来。
4.web容器要支持jsp的修改,jsp文件最终也是要编译成class文件才能在虚拟机中运行,web容器需要支持jsp修改后不用
重启。
  • 3.tomcat使用默认的类加载机制行不行?
不行
1.如果使用默认的类加载器机制,无法加载两个相同类库的不同版本的,默认的类加载器是不管是什么版本,
只在乎全限定名类,并且只有一份。
2.无法实现jsp文件的热替换,jsp文件其实是class文件,如果修改,类名还是一样,类加载器会直接取方法
区中已经存在的,修改后的jsp是不会重新加载的。每个jsp文件对应一个唯一的类加载器,当一个jsp文件修
改了,就直接卸载这个jsp类加载器,重新创建类加载器,重新加载jsp文件。
  • 4.tomcat的CommonClassLoader如何加载WebAppClassLoader中的类?
可以使用线程上下文类加载器实现,使用线程上下文加载器,可以让父类加载器请求子类加载器去完成类加载的动作。
  • 5.为什么java文件放在Eclipse/IDEA中的src文件夹下会优先jar包中的class?
1.因为Eclipse/IDEA中src文件夹中的文件java以及webContent中的JSP都会在tomcat启动时,被编译成class文件放在
WEB-INF/class中。
2.Eclipse/IDEA外部引用的jar包,则相当于放在WEB-INF/lib中。
3.应用类加载器在WEB-INF/classes中加载优先于在WEB-INF/lib中加载。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2054320.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

初识指针3の学习笔记

目录 1>>前言 2>>冒泡排序 3>>二级指针 4>>指针数组 5>>指针数组模拟二维数组 6>>结语 1>>前言 今天我会继续分享一些我做的笔记,以及我对指针的理解, 后续会持续分享指针几天,毕竟指针的内…

实验室安全分级分类管理系统在高校中的具体应用

盛元广通高校实验室安全分级分类管理系统的构建,旨在通过科学合理的管理手段,提高实验室的安全水平,保障师生的人身安全,防止实验事故的发生。这一系统通常包括实验室安全等级评估、分类管理、风险控制、安全教育与培训、应急响应…

[Qt][绘图][上]详细讲解

目录 0.为什么?1.绘图API核心类2.设置画笔3.设置画刷4.设置画家1.移动画家位置2.保存/加载画家的状态 0.为什么? 虽然Qt已经内置了很多的控件,但是不能保证现有控件就可以应对所有场景,很多时候,需要更强的"定制…

第N8周:使用Word2vec实现文本分类

本文为365天深度学习训练营 中的学习记录博客原作者:K同学啊 一、数据预处理 任务说明: 本次将加入Word2vec使用PyTorch实现中文文本分类,Word2Vec 则是其中的一种词嵌入方法,是一种用于生成词向量的浅层神经网络模型,由Tomas M…

spring boot学习第二十篇:使用minio上传下载文件获取文件路径

先安装好minio&#xff0c;参考&#xff1a;window10安装minio-CSDN博客 1、pom.xml文件添加依赖&#xff1a; <!-- 操作minio的java客户端--><dependency><groupId>io.minio</groupId><artifactId>minio</artifactId><version>8.…

C语言:ifswitch分支语句

目录 前言 一、if语句 1.1 if 1.2 else 1.3 嵌套if 1.4 悬空else问题 二、switch语句 2.1 if语句和switch语句的对比 2.2 switch语句中的default 前言 C语⾔是结构化的程序设计语言&#xff0c;这里的结构指的是顺序结构、选择结构、循环结构&#xff0c;C语言是能够实…

大模型之战-操作数据表-coze

工作流直接操作数据库啦【何时可以直接访问自己的数据库呢】 1&#xff0c;第一步创建一个bot智能体 1.1&#xff0c;bot中创建数据库表&#xff1a; 1.2&#xff0c;智能体可以通过对话&#xff0c;操作表&#xff1b;【增加&#xff0c;筛选查询等】 1.2.1&#xff0c;增加…

视频美颜SDK与直播美颜工具的开发详解与技术优化

本篇文章&#xff0c;小编将为开发者提供一份详细的美颜指南。 一、视频美颜SDK的核心功能 视频美颜SDK是一种嵌入式软件开发工具包&#xff0c;允许开发者在应用中轻松实现实时美颜效果。其核心功能主要包括&#xff1a; 1.实时磨皮 2.美白功能 3.瘦脸与大眼 4.智能滤镜…

链式结构二叉树的应用

一、求二叉树节点的个数 思路1&#xff1a;将一棵二叉树分成根节点和它的左右子树&#xff0c;其左右子树又可以分成根节点和左右子树&#xff0c;运用函数递归的方式统计根节点的数量&#xff0c;将根节点的数量相加。 比如这颗二叉树&#xff0c;1是根节点&#xff0c;size&…

自闭症表现的全方位解读

自闭症&#xff0c;一种神经发育障碍&#xff0c;影响着许多儿童和家庭的生活。了解自闭症的表现对于早期诊断、干预和支持这些孩子至关重要。 自闭症的表现形式多样&#xff0c;且在不同个体之间可能存在较大差异。社交互动障碍是自闭症的核心症状之一。自闭症儿童往往在与人建…

【软件测试面试题】WEB功能测试(持续更新)

Hi&#xff0c;大家好&#xff0c;我是小码哥。最近很多朋友都在说今年的互联网行情不好&#xff0c;面试很难&#xff0c;不知道怎么复习&#xff0c;我最近总结了一份在软件测试面试中比较常见的WEB功能测试面试面试题合集&#xff0c;希望对大家有帮助。 建议点赞收藏再阅读…

《机器学习数据标准化》—— 0~1归一化 和 Z标准化

文章目录 1、为什么要数据标准化2、常用的两种数据标准化1、0~1归一化2、Z标准化 3、注意事项 1、为什么要数据标准化 主要是基于以下几个方面的原因&#xff1a; 消除量纲影响&#xff1a;在机器学习中&#xff0c;不同的特征往往具有不同的量纲和单位。例如&#xff0c;身高…

DHT11温湿度传感器详解(STM32)

目录 一、介绍 二、传感器原理 1.原理图 2.工作时序 3.起始信号与响应信号 4.读数据时序 5.DHT11数据格式 三、程序设计 main.c文件 dht11.h文件 dht11.c文件 四、实验效果展示 五、资料获取 项目分享 一、介绍 DHT11是一款含有已校准数字信号输出的温湿度复合传感器&…

commvault学习(9):备份mysql(linux平台)

1.全备份 1.1创建实例 在centos7上安装完带有mysql组件的cv客户端后&#xff0c;就能在CS上看到客户端的mysql选项 右击图中mysql&#xff0c;点击所有任务-新MySql Server 在弹出的配置框中进行如下设置&#xff1a; *服务器名&#xff1a;类似任务名&#xff0c;自行设置即…

基于SpringBoot的论坛系统设计与实现(源码+lw+部署文档+讲解等)

文章目录 前言具体实现截图详细视频演示技术栈系统测试为什么选择我官方认证玩家&#xff0c;服务很多代码文档&#xff0c;百分百好评&#xff0c;战绩可查&#xff01;&#xff01;入职于互联网大厂&#xff0c;可以交流&#xff0c;共同进步。有保障的售后 代码参考数据库参…

伊朗通过 ChatGPT 试图影响美国大选, OpenAI 封禁多个账户|TodayAI

OpenAI 近日宣布&#xff0c;他们已经封禁了一系列与伊朗影响行动有关的 ChatGPT 账户&#xff0c;这些账户涉嫌利用该 AI 工具生成并传播与美国总统选举、以色列 – 哈马斯战争以及奥运会等相关的内容。 OpenAI 表示&#xff0c;这些账户与一个名为 “Storm-2035” 的秘密伊朗…

(Arxiv-2023)潜在一致性模型:通过少步推理合成高分辨率图像

潜在一致性模型&#xff1a;通过少步推理合成高分辨率图像 Paper Title: Latent Consistency Models: Synthesizing High-Resolution Images with Few-Step Inference Paper是清华发表在Arxiv 2023的工作 Paper地址 Code地址 ABSTRACT 潜在扩散模型 (LDM) 在合成高分辨率图像方…

寻找峰值(100%用例)C卷(JavaPythonC++Node.jsC语言)

给定一个长度为n的数组nums,请你找到峰值并返回其索引。数组可能包含多个峰值,在这种情况下,返回任何一个所在位置即可。 1. 峰值 元素是指其值严格大于左右相邻值的元素 。严格大于即不能有等于 2.假设 nums[-1] = nums[n] = 3.对于所有有效的 i 都有 nums[i] != nums[…

dockerfile搭建部署LNMP

目录 实验 架构&#xff1a; 实验步骤&#xff1a; nginx部分 mysql部分 php部分 实验 实验&#xff1a;用dockerfile搭建LNMP论坛 架构&#xff1a; 一台docker虚拟机 docker部署nginx 1.22 指定ip地址172.111.0.10 docker部署mysql 8.0.30 指定ip地址…

机器学习常用包numpy篇(三)随机数

目录 前言 随机数的生成 1.指定形状 生成【0&#xff0c;1&#xff09;的随机数组 2.从标准正态分布中返回一个或多个样本值&#xff08;组成数组&#xff09; 3.生成规定区间内的规定形状的随机数组 4. 生成[0, 1) 区间内指定 size 的随机浮点数 数组 5.从给定的数组里…