打破双亲委派机制有什么用_tomcat打破双亲委派机制

tomcat在jvm提供的类加载器上进行了扩展,并且打破了双亲委托机制

CommonClassLoader、CatalinaClassLoader、SharedClassLoader和WebappClassLoader则是Tomcat自己定义的类加载器,它们分别加载/common/*、/server/*、/shared/*(在tomcat 6之后已经合并到根目录下的lib目录下)和/WebApp/WEB-INF/*中的Java类库。其中WebApp类加载器和Jsp类加载器通常会存在多个实例,每一个Web应用程序对应一个WebApp类加载器,每一个JSP文件对应一个Jsp类加载器。

commonLoader:Tomcat最基本的类加载器,加载路径中的class可以被Tomcat容器本身以及各个Webapp访问;

catalinaLoader:Tomcat容器私有的类加载器,加载路径中的class对于Webapp不可见;

sharedLoader:各个Webapp共享的类加载器,加载路径中的class对于所有Webapp可见,但是对于Tomcat容器不可见;

WebappClassLoader:各个Webapp私有的类加载器,加载路径中的class只对当前Webapp可见;

从图中的委派关系中可以看出:

CommonClassLoader能加载的类都可以被Catalina ClassLoader和SharedClassLoader使用,从而实现了公有类库的共用,而CatalinaClassLoader和Shared ClassLoader自己能加载的类则与对方相互隔离。

WebAppClassLoader可以使用SharedClassLoader加载到的类,但各个WebAppClassLoader实例之间相互隔离。

而JasperLoader的加载范围仅仅是这个JSP文件所编译出来的那一个.Class文件,它出现的目的就是为了被丢弃:当Web容器检测到JSP文件被修改时,会替换掉目前的JasperLoader的实例,并通过再建立一个新的Jsp类加载器来实现JSP文件的HotSwap功能。

好了,至此,我们已经知道了tomcat为什么要这么设计,以及是如何设计的,那么,tomcat 违背了java 推荐的双亲委派模型了吗?答案是:违背了。我们前面说过:

双亲委派模型要求除了顶层的启动类加载器之外,其余的类加载器都应当由自己的父类加载器加载。

很显然,tomcat 不是这样实现,tomcat 为了实现隔离性,没有遵守这个约定,每个webappClassLoader加载自己的目录下的class文件,不会传递给父类加载器。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
双亲委派机制(Parent-Delegation Model)是Java类加载器体系结构中的一项重要设计,它的工作原理是在类被请求时,先由当前类加载器寻找,如果找不到再委托给父级加载器查找。这样做的好处主要有: 1. 安全性:防止恶意代码替换系统类库,因为每个类加载器只负责加载自己的路径下的类。 2. 隔离性:避免类名冲突,子类加载器不会覆盖父加载器已经加载过的类。 然而,有时可能需要打破这种机制,比如: 1. 自定义类加载:当开发者希望在特定环境或上下文中动态加载类,例如Web应用程序中的Spring框架或第三方库可能需要自定义类加载策略。 2. 组合加载器:为了兼容多个版本的库或者需要处理不同版本之间的依赖冲突。 Tomcat作为Java Web应用服务器,提供了几种方法来打破双亲委派机制: 1. 使用`java.lang.instrument包`:这个API允许动态修改运行时类文件,可以在应用启动后,通过ClassFileTransformer接口改变类加载行为。 2. 在web.xml中配置`<loader>`元素:对于Servlet或JSP等资源,可以通过 `<Context>` 标签内的 `<Loader>` 元素来指定一个非标准的类加载器,如`org.springframework.web.context.support.AnnotationConfigWebApplicationContext$AnnotationConfigwarClassLoader`。 3. 使用`WebappLoader`或`CustomClassLoader`:这些类允许创建一个自定义的类加载器,用于Tomcat应用中的某个特定区域。 总之,打破双亲委派机制是为了满足特殊需求,但在实际操作中需要谨慎,因为它可能会引入安全风险和复杂性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值