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