项目场景
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
- 忽略不管
注意,解决后,需要验证测试;
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/155612.html