Tomcat学习积累笔记---Tomcat类加载机制

Tomcat学习积累笔记—Tomcat类加载机制

1. Java类(.java)—> 字节码⽂件(.class) —> 字节码⽂件需要被加载到jvm内存当中(这个过程就是⼀个类加载的过程)
2. 在类加载机制中有个很重要的角色:类加载器(ClassLoader,说⽩了也是⼀个类,jvm启动的时候先把类加载器读取到内存当中去,其他的类(⽐如各种jar中的字节码⽂件,⾃⼰开发的代码编译之后的.class⽂件等等))

1.JVM类加载机制

1. JVM 的类加载机制中有⼀个⾮常重要的⻆⾊叫做类加载器(ClassLoader),类加载器有⾃⼰的体系,JVM内置了⼏种类加载器,包括:引导类加载器扩展类加载器系统类加载器,他们之间形成⽗⼦关系,通过 Parent 属性来定义这种关系,最终可以形成树形结构。
2. 系统类加载器的父类是扩展类加载器,引导类加载器是扩展类加载器的父类

在这里插入图片描述

3. 三个引导器的区别 ,加载的class文件不同,不同的目录是由于不同的目录加载出来的

在这里插入图片描述

4. 另外:⽤户可以⾃定义类加载器(Java编写,⽤户⾃定义的类加载器,可加载指定路径的 class ⽂件)
5. 当 JVM 运⾏过程中,⽤户⾃定义了类加载器去加载某些类时,会按照下⾯的步骤(⽗类委托机制)
  1. ⽤户⾃⼰的类加载器,把加载请求传给⽗加载器,⽗加载器再传给其⽗加载器,⼀直到加载器树的顶层
  2. 最顶层的类加载器⾸先针对其特定的位置加载,如果加载不到就转交给⼦类
  3. 如果⼀直到底层的类加载都没有加载到,那么就会抛出异常 ClassNotFoundException。因此,按照这个过程可以想到,如果同样在 classpath 指定的⽬录中和⾃⼰⼯作⽬录中存放相同的class,会优先加载 classpath ⽬录中的⽂件

2.JVM双亲委派机制

1.什么是双亲委派机制
  1. 当某个类加载器需要加载某个.class⽂件时,它⾸先把这个任务委托给他的上级类加载器,递归这个操作,如果上级的类加载器没有加载,⾃⼰才会去加载这个类。
2. 双亲委派机制的作⽤
  1. 防⽌重复加载同⼀个.class。通过委托去向上⾯问⼀问,加载过了,就不⽤再加载⼀遍。保证数据安全。
  2. 保证核⼼.class不能被篡改。通过委托⽅式,不会去篡改核⼼.class,即使篡改也不会去加载,即使加载也不会是同⼀个.class对象了。不同的加载器加载同⼀个.class也不是同⼀个.class对象。这样保证了class执⾏安全(如果⼦类加载器先加载,那么我们可以写⼀些与java.lang包中基础类同名的类, 然后再定义⼀个⼦类加载器,这样整个应⽤使⽤的基础类就都变成我们⾃⼰定义的类了。)
  3. Object类 -----> ⾃定义类加载器(会出现问题的,那么真正的Object类就可能被篡改了)

3.Tomcat类加载机制剖析

  1. Tomcat 的类加载机制相对于 Jvm 的类加载机制做了⼀些改变。没有严格的遵从双亲委派机制,也可以说打破了双亲委派机制,⽐如: 有⼀个tomcat,webapps下部署了两个应⽤
    app1/lib/a-1.0.jar com.lagou.edu.Abc
    app2/lib/a-2.0.jar com.lagou.edu.Abc
    不同版本中Abc类的内容是不同的,代码是不⼀样的
    在这里插入图片描述
  2. 引导类加载器 和 扩展类加载器 的作⽤不变
  3. 系统类加载器正常情况下加载的是 CLASSPATH 下的类,但是 Tomcat 的启动脚本并未使⽤该变量,⽽是加载tomcat启动的类,⽐如bootstrap.jar,通常在catalina.bat或者catalina.sh中指定。位于CATALINA_HOME/bin下
  4. Common 通⽤类加载器加载Tomcat使⽤以及应⽤通⽤的⼀些类,位于CATALINA_HOME/lib下,⽐如servlet-api.jar
  5. Catalina ClassLoader ⽤于加载服务器内部可⻅类,这些类应⽤程序不能访问
  6. Shared ClassLoader ⽤于加载应⽤程序共享类,这些类服务器不会依赖
  7. Webapp ClassLoader,每个应⽤程序都会有⼀个独⼀⽆⼆的Webapp ClassLoader,他⽤来加载本应⽤程序 /WEB-INF/classes 和 /WEB-INF/lib 下的类。
tomcat 8.5 默认改变了严格的双亲委派机制
  1. ⾸先从 Bootstrap Classloader加载指定的类
  2. 如果未加载到,则从 /WEB-INF/classes加载
  3. 如果未加载到,则从 /WEB-INF/lib/*.jar 加载
  4. 如果未加载到,则依次从 System、Common、Shared 加载(在这最后⼀步,遵从双亲委派机制)
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值