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

[经验分享] tomcat 下 部署多工程 jar (Tomcat的类库加载的优先顺序一览 )

[复制链接]

尚未签到

发表于 2015-8-9 00:28:27 | 显示全部楼层 |阅读模式
  问题:现在有5个工程。里面都使用了spring mvc spring security 和相同的一些jar包
可以把jar 包 都 抽到 tomcat lib 下 或 jre lib 下吗?
要是可以。会不会对工程有什么影响。
  回答:
  可以,但个人不建议这样
因为像common\lib下的包是相对很通用又稳定的包
如果你把你这几个工程共用的几个相同包放进来
一定时间看起来是文件少了不少
但将来需求的变化,可能有的工程 需要比较新版本LIB包,而一些工程 又没有需求或升级的要求 ,还只是要老版本的LIB包,同时新版本的lib包又依赖一些其他的包,并得删除掉一些如果放进去会产生错误的包。。。。。返正就是包的依赖比较麻烦时
你可能只考虑到一个工程 ,而另一个工程 没考虑到时就麻烦了。。。

还有,不同的中间件,classloader的加载顺序 还不一样
tomcat,jetty,jboss,websphere,weblogic等 可能会有一些地方不同,所以能部署到TOMCAT上的工程,不一定把整个WAR包放到JBOSS下就能正常跑起来,(虽然jboss是基于tomcat)
像tomcat
http://blog.iyunv.com/myk_666888/article/details/5705208
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     
而weblogic是

在weblogic中的classloader有5个层次,从高到低排:
a. jdk
b. jdk ext
c. system classpath
d. ( APP-INF/classes  and  APP-INF/lib )
e. ( WEB-INF/classes and WEB-INF/lib )
http://www.blogjava.net/SpartaYew/archive/2011/05/18/350503.html
  Tomcat与Weblogic有些地方是相反的:对于运行在 Java EE 容器中的 Web 应用来说,类加载器的实现方式与一般的 Java 应用有所不同。不同的 Web 容器的实现方式也会有所不同。以 Apache Tomcat 来说,每个 Web 应用都有一个对应的类加载器实例。该类加载器也使用代理模式,所不同的是它是首先尝试去加载某个类,如果找不到再代理给父类加载器。这与一般类加载器的顺序是相反的。这是 Java Servlet 规范中的推荐做法,其目的是使得 Web 应用自己的类的优先级高于 Web 容器提供的类。这种代理模式的一个例外是:Java 核心库的类是不在查找范围之内的。这也是为了保证 Java 核心库的类型安全。
  参考:http://www.iteye.com/problems/69878

运维网声明 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-96157-1-1.html 上篇帖子: Linux下tomcat相关操作 下篇帖子: Tomcat:基于HTTP协议的Connector配置
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

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

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

扫描微信二维码查看详情

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


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


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


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



合作伙伴: 青云cloud

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