设为首页 收藏本站
查看: 391|回复: 0

[经验分享] 为什么tomcat要自定义classloader

[复制链接]

尚未签到

发表于 2017-1-25 12:21:46 | 显示全部楼层 |阅读模式
  一、 提起tomcat 中的classloader 莫过于经典的委托机制,上图:
  
                                                 DSC0000.png
 
  不过这个流传于世间的大图为tomcat5的classloader模型,对于目前比较主流的,支持nio 的tomcat7而言,classloader结构也不一样,tomcat7中的classloader委托模型:
  
                                                          DSC0001.png
  二、研究tomcat的类加载器结构之前,我们先来关注一下JVM中的classloader机制:
  jvm中默认定了三种classloader,分别为:bootstrap classloader, extension classloader, system classloader.
  bootstrap 使用c语言来实现,没有对应的ClassLoader对象。
  该方法String.class.getClassLoader() 返回null。
  extension 用于从jre/lib/ext 目录加载“标准的扩展”。
  system 用于加载应用类。由classpath环境变量中的 jar/zip 文件。
  除此之外,java的classloader采用委托机制,即classloader都有一个 parent classloader。当收到一个类加载请求时,会先请求parent classloader加载类,如果parent classloader家在不到,再由自身尝试加载(如果加载不到,throw ClassNotFountException). 这种机制主要是出于安全考虑,如果用户自定义一个java.lang.Object 不至于覆盖jdk中的Object。
  当然万事万物无绝对。OSGI就违反了这个原则。
  三、那么Tomcat为什么要自定义ClassLoader呢?
  我认为主要出于两方面原因:
  1 Servlet规范中对于类加载器的要求
  
DSC0002.png
 
  2 实现不同web app 的类隔离。
  各个classloader作用说明:
  1  bootstrap / extension: 加载$JAVA_HOME/jre/lib/ext下的类
  2  system: 加载由CLASSPATH初始化的所有类,对于tomcat自身类以及所有web应用的类可见。但是查看tomcat标准的启动脚本$CATALINA_HOME/bin/catalina.bat, 完全无视CLASSPATH,直接加载tomcat中的3个jar包。
  3  Common: 对于tomcat,和所有web app 可见,用于加载$CATALINA_BASE/conf/catalina.properties里面的类,通常应用程序的类不建议放在里面。默认加载:

common.loader=${catalina.base}/lib,${catalina.base}/lib/*.jar,${catalina.home}/lib,${catalina.home}/lib/*.jar
   
  4  WebappX: 加载所有WEB-INF/classes下面的类以及里面的jar。
  该classloader有意违背了委托原则。它首先看WEB-INF/classes中是否有请求的类,而不是委托parent classloader去处理,但是jre 和servlet api 不会被覆盖。
  以上就是对于tomcat 中的classloader的简单总结介绍。
   参考tomcat官方资料: http://tomcat.apache.org/tomcat-7.0-doc/class-loader-howto.html

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-333325-1-1.html 上篇帖子: Tomcat 设置内存和在eclipse中的设置 下篇帖子: How Tomcat Works中文版
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表