现在的位置: 首页 > 综合 > 正文

Log4J 1.2.15 jms maven M2Eclipse的Issue及解法

2013年08月20日 ⁄ 综合 ⁄ 共 1780字 ⁄ 字号 评论关闭

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

 

 

 

抱歉!评论已关闭.