Tomcat的类加载器

 

看完了Java类装载器,我们再来看看应用服务器(Tomcat)对类加载器的使用,每个应用服务器都有一套自己的类加载器体系,从而与Java的类加载器区别开以达到自己与应用程序隔离的目的.

Tomcat的类加载器体系为:Bootstrap--->System--->Common---->Catalina,Shared

Shared------>Webapp1,Webapp2 .....

下面是对每个类加载器的定义:

1.Bootstrap加载器在这里是Java里的Bootstrap和ExtClassLoader的总称,负责加载Java核心包的类,和<Java_Home>/jre/lib/ext目录下的类.通常我们开发人员并不关心.我想只要是java程序这些肯定是必要的

2.System就是系统加载器,一般是AppClassLoader,负责加载ClassPath环境变量设置目录下的值,这个我们开发人员会非常关注,但是在Tomcat里面,虽然用AppClassLoader类加载器,但我们设置的ClassPath对它没有影响(如果有影响,那就麻烦了,将会导致Tomcat运行不稳定),为什么呢,因为tomcat每次启动的时候都会在命令行窗口中都会重新设置Classpath值为:<catalina_Home>/bin/bootstrap.jar和<java_Home>/lib/tools.jar,所以这里面的类一般对应用程序不可见的.除非你设置了

3.Common类加载器负责加载TomcatHOME/common/class下的.Class文件和common/lib中的jar包,这些类可以被Tomcat内核和每个Web应用程序都可以看见,一般放公用的一些重要的类,如servlet.jar等

4.Catalina类加载器从server/classes和server/lib下加载类,Catalina加载的类只对Tomcat服务器内核可见,对Web应用程序不可见,对于运行Tomcat内核的线程,它的上下文类加载器就是Catalina类加载器

5.Shared类加载器负责从share/classes和share/lib中加载类,它加载的类只对所有Web应用程序有效,对Tomcat不可见.

6.WebappX类加载器负责加载Web应用程序的/web-INF/classes和lib目录下的类,只对当前Web应用程序有效,对其他Web应用程序无效,对于运行每个Web应用程序的线程,他们的上下文类加载器就是它们各自的WebappX类加载器

总结:从以上6点可以看出Tomcat提供了完整的类加载器体系,并且分工非常的明确,因而非常访问我们进行Web应用程序的设置和部署.

### Tomcat 类加载器工作原理 Tomcat 使用了一套复杂的类加载体系结构来支持 Web 应用程序的部署和运行。这套架构不仅遵循 Java 的双亲委派模型,还在此基础上进行了扩展以满足特定需求。 #### 1. 双亲委派模型 在标准 JVM 中,当一个类被请求时,JVM 不会立即尝试自己去加载这个类,而是先委托给父级类加载器处理。这种机制被称为双亲委派模式[^1]。通过这种方式,确保了核心库的安全性和一致性,防止应用程序覆盖基础框架中的重要组件。 #### 2. Tomcat 自定义类加载层次 为了更好地管理不同级别的资源访问权限以及实现更灵活的应用隔离策略,Tomcat 设计了一个多层嵌套式的类加载器结构: - **Common ClassLoader**: 负责加载位于 `$CATALINA_HOME/lib` 目录下所有 JAR 文件内的公共依赖包。这些库对于整个服务端都是可见并可重用的。 - **Catalina ClassLoader / Server ClassLoader**: 主要用于加载构成 Tomcat 核心功能模块所需的类文件;如果 `server.loader` 属性未指定,则此角色由 Common ClassLoader 承担[^2]。 - **Shared ClassLoader**: 提供给多个 webapps 共享使用的第三方 jar 包路径,默认情况下也是不存在于配置里的,除非显式设置了 `share.loader` 参数。 - **WebApp ClassLoaders (Per Application)**: 每个独立部署的应用都有自己的专属 classloader 实例 (`webappLoader`) ,负责读取 WEB-INF/classes 和 lib 子目录内私有的 .class 或者 .jar 文档。这保证了各个项目间不会互相干扰的同时也方便维护各自的环境设置[^3]. ```xml <!-- Example of setting up custom loaders in catalina.properties --> server.loader=extra-server-jars/* shared.loader=common-dependencies/* ``` 上述 XML 片段展示了如何修改 `catalina.properties` 来激活额外的服务级别或共享范围内的类加载选项。注意这里的通配符表示法允许一次性引入同级目录下的全部符合条件的目标对象。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值