tomcat 下 部署多工程 jar (Tomcat的类库加载的优先顺序一览 )

不同的中间件(tomcat,jetty,jboss,websphere,weblogic),classloader的加载顺序不一样.

所以能部署到TOMCAT上的工程,不一定把整个WAR包放到JBOSS下就能正常跑起来(虽然jboss是基于tomcat).  


Tomcat的class加载的优先顺序:

1.最先是$JAVA_HOME/jre/lib/ext/下的jar文件。   
2.环境变量CLASSPATH中的jar和class文件。   
3.$CATALINA_HOME/common/classes下的class文件。   
4.$CATALINA_HOME/commons/endorsed下的jar文件。   
5.$CATALINA_HOME/commons/i18n下的jar文件。   
6.$CATALINA_HOME/common/lib   下的jar文件。   
(JDBC驱动之类的jar文件可以放在这里,这样就可以避免在server.xml配置好数据源却出现找不到JDBC   Driver的情况。)   
7.$CATALINA_HOME/server/classes下的class文件。   
8.$CATALINA_HOME/server/lib/下的jar文件。   
9.$CATALINA_BASE/shared/classes   下的class文件。   
10.$CATALINA_BASE/shared/lib下的jar文件。   
11.各自具体的webapp   /WEB-INF/classes下的class文件。   
12.各自具体的webapp   /WEB-INF/lib下的jar文件。   

Class的搜寻顺序:   
-------------   
Bootstrap classes of your JVM     
System class loader classses (described above)     
/WEB-INF/classes of your web application     
/WEB-INF/lib/*.jar  of your web application     
$CATALINA_HOME/common/classes     
$CATALINA_HOME/common/endorsed/*.jar     
$CATALINA_HOME/common/i18n/*.jar     
$CATALINA_HOME/common/lib/*.jar     
$CATALINA_BASE/shared/classes     
$CATALINA_BASE/shared/lib/*.jar     

以 Tomcat 来说,每个 Web 应用都有一个对应的类加载器实例。该类加载器也使用代理模式,所不同的是它是首先尝试去加载某个类,如果找不到再代理给父类加载器。这与一般类加载器的顺序是相反的。

这是 Java Servlet 规范中的推荐做法,其目的是使得 Web 应用自己的类的优先级高于 Web 容器提供的类。

这种代理模式的一个例外是:Java 核心库的类是不在查找范围之内的。这也是为了保证 Java 核心库的类型安全。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值