类加载器就是根据类的全限定名(例如com.ty.xxx.xxx)来获取此类的二进制字节流的代码模块,从而程序可以自己去获取到相关的类。

一、java中的类加载器

  1、类加载器类别

java中的类加载器主要分为三类:

Bootstrap ClassLoader:启动类加载器,负责加载<JAVA_HOME>\lib目录中的class文件;

Extension ClassLoader:扩展类加载器,负责加载<JAVA_HOME>\lib\ext路径下的class文件;

Application ClassLoader:应用程序类加载器,也称为系统类加载器。负责加载用户路径上所指定的类库,开发者可以直接使用,如果开发者没有自己定义类加载器,一般就是使用此类加载器。

类加载器的层次结构如下:

2、双亲委派模型

要求:除了顶层的启动类加载器之外,其他的类加载器都必须具有父类

解释:如果一个类加载器收到了加载类的请求,首先并不会自己尝试加载这个类,而是将请求委派给父类加载器完成,父类又去委派给其父类,因此最终的请求都到了顶层,若顶层类加载器无法加载,子类再尝试自己加载。

好处:费了这么大劲,到底有啥好处呢?

按照双亲委派模型加载类,会让类首先有一种层次感,或者说是上下级感。最顶层的类加载器只加载<JAVA_HOME>\lib下的class文件,这是jdk的核心所在,当然也是凌驾于开发者所创建的class文件。并且能够保证整个jvm中,所有的基础类,例如Object等等,

都是同一个类。哪怕程序员自己创建了java.lang.object类,编译可以通过,但是永远不会被加载。

3、java委派过程

a、从缓存中加载;

b、如果缓存中没有,则从父类尝试加载;

c、如果父类加载器中没有,则从当前类加载器加载;

d、如果没有,则抛出异常。

二、Tomcat中的类加载

  Tomcat中的类加载没有遵循双亲委派模型,为啥?双亲委派说的这么吊,为什么Tomcat不使用这种方式加载类?

Tomcat类加载器需要解决的问题:

1、解决不同应用中使用某一第三方库的不同版本

因为将web应用部署到Tomcat中,不同应用很有可能会使用到同一类库,例如某第三方库,并且使用了不同版本。这时如果使用jvm默认的类加载的机制,不同版本的类只会保存一种,因为他认的只有全限定名,例如com.ty.xxx.xxx.class,这样不同应用就无法

做到隔离,显然是不行的。

2、 部署在同一个web容器中相同的类库相同的版本可以共享

这样做很明显是为了防止资源浪费。

3、Tomcat作为应用服务器,也有自己所依赖的类,需要与web应用隔离

基于安全考虑,应该让容器的类库和程序的类库隔离开来。

4、支持jsp的热修改

jsp的本质也是servlet,jsp在程序中使用也是编译成servlet才能发挥作用。修改jsp则是非常常见的事情,那对于类加载器来说,jsp的类名并没有更改,因此按照默认的类加载机制,会直接从方法区中去class文件。Tomcat为了解决这个问题,将每个jsp

都对应一个类加载器,jsp发生修改后,直接销毁此类加载器,重新生成,然后加载修改后的文件。

设计图如下:

  commonLoader:Tomcat最基本的类加载器,加载路径中的class可以被Tomcat容器本身以及各个Webapp访问;
  catalinaLoader:Tomcat容器私有的类加载器,加载路径中的class对于Webapp不可见;
  sharedLoader:各个Webapp共享的类加载器,加载路径中的class对于所有Webapp可见,但是对于Tomcat容器不可见;
  WebappClassLoader:各个Webapp私有的类加载器,加载路径中的class只对当前Webapp可见;

Tomcat类加载器加载顺序(对于WebApp ClassLoader来说):

a、从缓存中加载;

b、如果没有,则从JVM的Bootstrap类加载器加载;

c、如果没有,则从当前类加载器加载(按照WEB-INF/classes、WEB-INF/lib的顺序);

d、如果没有,则从父类加载器加载,由于父类加载器采用默认的委派模式,因此加载顺序为Extension ClassLoader-->Application ClassLoader-->Common ClassLoader-->Shared ClassLoader

Tomcat架构解析(五)-----Tomcat的类加载机制的更多相关文章

  1. Tomcat架构解析(一)-----Tomcat总体架构

    Tomcat是非常常用的应用服务器,了解Tomcat的总体架构以及实现细节,对于理解整个java web也是有非常大的帮助. 一.Server   1.最简单的服务器结构 最简单的服务器结构如图所示: ...

  2. 浅读tomcat架构设计之tomcat生命周期(2)

    浅读tomcat架构设计和tomcat启动过程(1) https://www.cnblogs.com/piaomiaohongchen/p/14977272.html tomcat通过org.apac ...

  3. 浅读tomcat架构设计之tomcat容器Container(3)

    浅读tomcat架构设计和tomcat启动过程(1) https://www.cnblogs.com/piaomiaohongchen/p/14977272.html 浅读tomcat架构设计之tom ...

  4. Tomcat架构解析(二)-----Connector、Tomcat启动过程以及Server的创建过程

    Connector用于跟客户端建立连接,获取客户端的Socket,交由Container处理.需要解决的问题有监听.协议以及处理器映射等等. 一.Connector设计   Connector要实现的 ...

  5. Tomcat请求处理过程(Tomcat源代码解析五)

    watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQv/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/ ...

  6. 浅读tomcat架构设计和tomcat启动过程(1)

    一图甚千言,这张图真的是耽搁我太多时间了: 下面的tomcat架构设计代码分析,和这张图息息相关. 使用maven搭建本次的环境,贴出pom.xml完整内容: <?xml version=&qu ...

  7. Tomcat架构解析(三)-----Engine、host、context解析以及web应用加载

    上一篇博文介绍了Server的创建,在Server创建完之后,就进入到Engine的创建过程,如下: 一.Engine的创建   1.创建Engine实例 当前次栈顶元素为Service对象,通过Se ...

  8. Tomcat架构解析(六)-----BIO、NIO、NIO2、APR

    对于应用服务器来说,性能是非常重要的,基本可以说决定着这款应用服务器的未来.通常从软件角度来说,应用服务器性能包括如下几个方面: 1.请求处理的并发程度,当前主流服务器均采用异步的方式处理客户端的请求 ...

  9. Tomcat架构解析(四)-----Coyote、HTTP、AJP、HTTP2等协议

    Connector是Tomcat中非常重要的一个组成部分,说白了,就是如何从客户端获取到相应的请求信息.这部分主要包括的难点有这样几个部分: 1.客户端与服务端的协议 客户端与服务端的协议是多种多样的 ...

随机推荐

  1. 详解卷积神经网络(CNN)

    详解卷积神经网络(CNN) 详解卷积神经网络CNN 概揽 Layers used to build ConvNets 卷积层Convolutional layer 池化层Pooling Layer 全 ...

  2. github 添加wiki

    亲们支持我的新博客哦==>地址(以后更新会尽量在新博客更新,欢迎大家访问加入我的后宫w) ) 平时都是写readMe和docs的,一直眼瞎没有注意到有wiki这个功能 随便找一个写了wiki的看 ...

  3. Android 开发 框架系列 glide-transformations 图片处理基本使用

    首先简单的介绍一下Gilde作用范围.Gilde功能十分强大,它可以实现图片处理.图片本地加载.图片网络加载.位图加载.图片内存缓存.图片磁盘缓存.Gif图片加载.使用简单轻松,轻松的后是它强大的心, ...

  4. 在BootStrap的modal中使用Select2搜索框无法输入

    用modal来show一个对话框 dialog.modal({ backdrop:true, keyboard:true, show:true }); 1 2 3 4 5 然后再modal中初始化se ...

  5. ORACLE重装之后恢复数据库,相当于sqlserver的附加数据库

    在开发机器上经常会遇到重装系统的问题,重装之前如果ORACLE没有及时备份的话重装之后就纠结了,数据还原很头疼. 各种娘中只能找到一些ORACLE安装与重装系统前目录相同的解决办法,目录不同就没招了. ...

  6. http 文件上传协议图览

  7. Redis内存模型总结

    一.Redis内存统计 在客户端通过redis-cli连接服务器后,通过info命令可以查看内存使用情况: info memory 返回结果中比较重要的几个说明如下: (1)used_memory:R ...

  8. Android应用开发中,第三方集成新浪微博(sinaWeiboSDK)的过程记录

    作为一个android开发人员,不可避免的要学会使用和集成第三方API的能力 而新浪微博作为现在最主要的新闻速递媒体,使用十分普遍,并且提供了较为详细的API接入方法,故此选择集成sinaWeibiS ...

  9. C# 数值的隐式转换

    Debug2.Log(5/8.0f, 5.0f/8, 5/8);//output:0.625, 0.625, 0 隐式数值转换表

  10. Ado.net之连接数据库

    一.Ado.net的核心 Ado.net的核心为两组重要的类,一个负责处理软件内部的实际数据(DataSet),另一个负责与外部数据系统通信(DataProvider) DataSet:包含一个或多个 ...