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