Log4J 1.2.15 jms maven M2Eclipse的Issue及解法

来源:互联网 发布:mac抹除数据 编辑:程序博客网 时间:2024/06/09 18:43

Jar Hell III: Log4J 1.2.15在M2Eclipse的Issue及解法  

Log4J的1.3版還在阿法貝塔階段。1.2版最新到1.2.15,但用於Eclipse上的Maven2卻有個Issue。

在執行Maven Clean後再執行Maven Package會Build Failure,有以下的錯誤訊息:[WARNING] Invalid POM for javax.jms:jms:jar:1.1, transitive dependencies (if any) will not be available, enable debug logging for more details[WARNING] Invalid POM for com.sun.jdmk:jmxtools:jar:1.2.1, transitive dependencies (if any) will not be available, enable debug logging for more details[WARNING] Invalid POM for com.sun.jmx:jmxri:jar:1.2.1, transitive dependencies (if any) will not be available, enable debug logging for more details  

這些loss的Jar在repository都空有其pom.xml檔卻無其 jar檔。反而使用Eclipse的Project/Clean後,再執行Maven Package才能Build Success。但回到1.2.14版卻無此問題,經過Dependency Graph才得知Log4J 1.2.15依賴上述三個Jar之故。

為何經過Project/Clean後再Package就沒問題?唔!無解,可能是循環依賴所致吧!  2010/3/11補述。後來找到引用1.2.15的解法,dependency設定如下:

log4j log4j 1.2.15 javax.jms jms com.sun.jdmk jmxtools com.sun.jmx jmxri javax.mail mail   

利用排除之法就能引用1.2.15來Maven Package。

<dependency>
    <groupId>log4j</groupId>
    <artifactId>log4j</artifactId>
    <version>1.2.15</version>
        <exclusions>
       <exclusion>
      <groupId>javax.jms</groupId>
      <artifactId>jms</artifactId>
       </exclusion>
       <exclusion>
      <groupId>com.sun.jdmk</groupId>
      <artifactId>jmxtools</artifactId>
       </exclusion>
       <exclusion>
      <groupId>com.sun.jmx</groupId>
      <artifactId>jmxri</artifactId>
       </exclusion>
       <exclusion>
      <groupId>javax.mail</groupId>
      <artifactId>mail</artifactId>
       </exclusion>
    </exclusions>
</dependency>

 

比较恶心的是如果这个依赖的构件在父pom声明,子工程会继承依赖关系,但不会继承exclusion属性!!

不知道是maven的BUG,还是我没有好好阅读手册的缘故

 

抱怨下nexus(版本号nexus-oss-webapp-1.7.2)这玩艺儿也是有BUG,通过界面去配置的时候,动不动CPU 100%

新版本的nexus(1.8) 又有jetty null问题,真FK,还有那个m2eclipse,不把依赖关系告诉你,导致安装了一堆三方插件还是

不能用,或者安装三方插件又碰到复杂的依赖错误,真是搞死掉!

 

 

2010/5/12補充:1.2.16版就沒這個情形。      ---> 1.2.16 不知道为啥maven仓库只有pom