首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >等级依赖管理-传递依赖版本不正确

等级依赖管理-传递依赖版本不正确
EN

Stack Overflow用户
提问于 2016-07-26 11:10:29
回答 1查看 1.6K关注 0票数 4

我在2016年IntelliJ IDEA中编辑了两个使用等级依赖管理的项目:项目A和项目B。

项目A将elasticsearch的编译范围依赖项定义为:

代码语言:javascript
复制
    compile 'org.elasticsearch:elasticsearch:2.3.1'

项目B声明了项目A的编译范围依赖项,如下所示:

代码语言:javascript
复制
    compile 'com.mycompany:elasticsearch-common:2.3.1'

我希望在2016年IntelliJ IDEA中的Gradle工具窗口中,项目B可以看到:

代码语言:javascript
复制
...
com.mycompany:elasticsearch-common:2.3.1 (Compile)
    org.elasticsearch:elasticsearch:2.3.1 (Compile)
...

相反,我看到:

代码语言:javascript
复制
...
com.mycompany:elasticsearch-common:2.3.1 (Compile)
    org.elasticsearch:elasticsearch:1.5.2 (Compile)
...

项目B中没有其他依赖项依赖于elasticsearch,因此它不会被另一个依赖项声明覆盖。

事实上,我们在项目A的关系上的pom.xml是这样的:

代码语言:javascript
复制
<dependency>
    <groupId>org.elasticsearch</groupId>
    <artifactId>elasticsearch</artifactId>
    <version>2.3.1</version>
    <scope>compile</scope>
</dependency>

那么,为什么IntelliJ报告elasticsearch的传递版本为1.5.2?

我试过的是:

  1. 删除项目B目录中的.idea和.gradle
  2. 删除gradle缓存
  3. 在IntelliJ中使缓存无效并重新启动
  4. 咒骂
  5. 喝很多茶
  6. 询问朋友和同事
  7. 发邮件给奥普拉
  8. 当所有这些都很好的时候,恢复到IntelliJ 15 (现在不再是了)
  9. 上厕所(与5相关),希望我回来后它能神奇地自我修复。

上述任何一项都不起作用。

在项目B中具体指定elasticsearch:2.3.1依赖项是什么工作,但这不否定传递依赖关系的全部原因吗?

任何帮助都是非常感谢的。

更新1

正如LanceJava在评论中所建议的那样,我运行gradle dependencies来查看发生了什么。

这表明它特别降低了它的评级:

代码语言:javascript
复制
org.elasticsearch:elasticsearch:2.3.1 -> 1.5.2

当我在这个依赖项上运行gradle dependencyInsight时,它产生了:

代码语言:javascript
复制
:dependencyInsight
com.mycompany:elasticsearch-common:2.3.1 (selected by rule)
\--- compile

org.elasticsearch:elasticsearch:1.5.2 (selected by rule)

org.elasticsearch:elasticsearch:2.3.1 -> 1.5.2
\--- com.mycompany:elasticsearch-common:2.3.1
     \--- compile

有人知道为什么会这样吗?

更新2

这似乎有答案:https://discuss.gradle.org/t/excluded-dependence-comes-back-when-spring-boot-plugin-is-applied/17945/2

看来,gradle spring-boot插件喜欢接管一些,并强制执行它自己的依赖版本(尽管我没有使用使用spring-data的spring启动程序)。

我修正了这一点,增加了:

代码语言:javascript
复制
ext[elasticsearch.version] = '2.3.1'

到我的build.gradle文件。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2016-07-27 09:00:44

问题中没有明确指出的是,这个项目使用的是spring-boot gradle插件,它强制执行某些版本的库,并强制降级我的弹性搜索版本,以使其与它的春季数据需求保持一致(尽管我的项目中没有使用spring数据)。

我通过执行以下操作发现了这一点:

代码语言:javascript
复制
gradle dependencyInsight --dependency elasticsearch --configuration compile

当时的结果是:

代码语言:javascript
复制
org.elasticsearch:elasticsearch:1.5.2 (selected by rule) 

org.elasticsearch:elasticsearch:2.3.1 -> 1.5.2 
   \--- com.mycompany:elasticsearch-common:2.3.1 
       \--- runtime

我了解到(selected by rule)部分意味着某些东西是通过编程选择特定版本的。这把它缩小到了插件的范围。

我只使用了4个插件:

  1. java
  2. maven
  3. 想法
  4. 弹簧靴

我唯一没有在其他地方使用的插件(因此在其他地方也没有遇到这个问题)是spring-boot

一旦我评论了这个插件,我就可以看到这种依赖是正确的。

在这一点上,我了解到我需要显式地指定我希望通过以下方式使用的版本:

代码语言:javascript
复制
ext[elasticsearch.version] = '2.3.1'

整理好了。给我再来点茶!

票数 4
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/38588271

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档