Maven 版本在哪里被覆盖?

where does the maven version get overridden?

我正在构建一个 spring 引导启动器,遵循与核心/自动配置/启动器模块分离的推荐约定。当我查看 maven 依赖树时,这就是我所拥有的:

[INFO] com.myDomain.myProject:myProject-starter:jar:1.0.8-SNAPSHOT
[INFO] +- com.myDomain.myProject:myProject-autoconfigure:jar:1.0.8-SNAPSHOT:compile
[INFO] |  \- com.myDomain.myProject:myProject-core:jar:1.0.8-SNAPSHOT:compile
[INFO] |     +- io.github.openfeign:feign-gson:jar:9.5.1:compile
[INFO] |     |  +- io.github.openfeign:feign-core:jar:9.5.1:compile
[INFO] |     |  \- com.google.code.gson:gson:jar:2.8.5:compile

gson 出现在 v2.8.5 中,这是我期望的版本 - 我的项目使用它

(注意:在 https://mvnrepository.com/artifact/io.github.openfeign/feign-core/9.5.1 中,我们看到 gson 的预期版本是 2.5...所以不确定为什么我得到 2.8.5..)

在我的根 pom.xml 中,我这样声明 BOM:

<dependencyManagement>
    <dependencies>
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-openfeign-dependencies</artifactId>
            <version>2.0.1.RELEASE</version>
            <type>pom</type>
            <scope>import</scope>
        </dependency>
    </dependencies>
</dependencyManagement>

在我的 "core" pom.xml 中:

<dependencies>
    <dependency>
        <groupId>org.springframework.cloud</groupId>
        <artifactId>spring-cloud-starter-openfeign</artifactId>
    </dependency>

    <dependency>
        <groupId>io.github.openfeign</groupId>
        <artifactId>feign-gson</artifactId>
    </dependency>

    <dependency>
        <groupId>io.github.openfeign</groupId>
        <artifactId>feign-httpclient</artifactId>
    </dependency>
</dependencies>

现在,在另一个项目中,我使用启动器。所以我的 pom.xml 很简单 :

<dependencies>
    <dependency>
        <groupId>com.myDomain.myProject</groupId>
        <artifactId>myProject-starter</artifactId>
        <version>1.0.8-SNAPSHOT</version>
    </dependency>
</dependencies>

当我查看这个项目中的依赖树时,我得到了这个:

[INFO] \- com.myDomain.myProject:myProject-starter:jar:1.0.8-SNAPSHOT:compile
[INFO]    +- com.myDomain.myProject:myProject-autoconfigure:jar:1.0.8-SNAPSHOT:compile
[INFO]    |  \- com.myDomain.myProject:myProject-core:jar:1.0.8-SNAPSHOT:compile
[INFO]    |     +- io.github.openfeign:feign-gson:jar:9.5.1:compile
[INFO]    |     |  +- io.github.openfeign:feign-core:jar:9.5.1:compile
[INFO]    |     |  \- com.google.code.gson:gson:jar:2.5:compile

gson 在 v2.5 中出现,因此它不起作用。 如果我在 pom.xml 中覆盖它,通过声明 gson 2.8.5在启动器之前,然后就可以了..

但是在 Maven 的工作方式中一定有一些我遗漏的东西..

我尝试从我的本地存储库中删除 1.0.8-snapshot 版本,然后重建它,以确保我的第二个项目没有使用旧版本,但我在构建中不断得到这个不正确的版本,我不知道它来自哪里/是什么覆盖了它。

如果您想在本地尝试一下代码,可以在这个分支中找到:https://github.com/societe-generale/github-crawler/tree/sprinBoot2upgrade

我真的对任何调查指针感兴趣,以了解根本原因,因为我现在很困惑..

谢谢!

=========================================

编辑 1

如评论中所述,Spring 引导启动程序将 gson 版本覆盖为 2.8.5(而不是 feign-core 中计划的 2.5)。

所以现在问题变成了:为什么当我在另一个没有父项目的项目中将启动器用作单一依赖项时,覆盖的版本 (2.8.5) 消失了,我最终得到了初始版本 (2.5)与 spring-boot-autoconfigure 2.0 不兼容。4.RELEASE ?

编辑 2

我在这里创建了一个新的、更有针对性的问题:Not getting the expected version when using the Spring Boot starter I built

根据问题评论中的各种提示快速总结

详细模式是 ,所以使用 mvn dependency:tree -X 获取有关版本 used/overridden 等的更多详细信息。然后你会得到类似的东西:

[DEBUG] io.github.openfeign:feign-gson:jar:9.5.1:compile 
[DEBUG]    com.google.code.gson:gson:jar:2.8.5:compile (version managed from 2.5 by org.springframework.boot:spring-boot-dependencies:2.0.4.RELEASE)

-> 这很清楚地指出了版本的来源,即 https://github.com/spring-projects/spring-boot/blob/v2.0.4.RELEASE/spring-boot-project/spring-boot-dependencies/pom.xml#L65