项目场景
JDK 11
问题描述
Maven项目本地编译时,编译日志中出现下面的warning
提示:
[WARNING] The POM for com.alibaba:druid:jar:1.2.6 is invalid, transitive dependencies (if any) will not be available, enable debug logging for more details
原因分析
按照提示,打印出Maven编译过程中的debug信息,给之前的maven命令后面加上 -X
mvn clean package -DskipTests=true -X
可以看到下面的详细信息:
[WARNING] The POM for com.alibaba:druid:jar:1.2.6 is invalid, transitive dependencies (if any) will not be available: 2 problems were encountered while building the effective model for com.alibaba:druid:1.2.6
[ERROR] 'dependencies.dependency.systemPath' for com.sun:tools:jar must specify an absolute path but is ${project.basedir}/lib/openjdk-1.8-tools.jar @
[ERROR] 'dependencies.dependency.systemPath' for com.sun:jconsole:jar must specify an absolute path but is ${project.basedir}/lib/openjdk-1.8-jconsole.jar @
从日志看, com.sun:tools:jar和com.sun:jconsole:jar 必须指定绝对路径,不能是相对路径。但是又指定的是 openjdk.
上面的定义的路径可以在druid-1.2.6.pom文件中找到:
~/.m2/repository/com/alibaba/druid/1.2.6/druid-1.2.6.pom
看了上面也就确定具体原因了:
- 开发环境使用的JDK和 com.alibaba.druid 包不一致;
- 这是 com.alibaba.druid 的一个bug,未考虑不同JDK环境的影响
解决方案
- 切换到其他版本,如 1.2.5
- 注释掉这两个依赖。正常开发没有影响
- 使用OpenJDK
- 忽略不管
注意,解决后,需要验证测试;
版权声明:本文为u014163312原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。