java - 强制使用旧 Maven 插件版本的任何正当理由?

标签 java maven project pom.xml

我在一个大型遗留项目上工作,我注意到在项目根 pom 中我们明确强制使用某些 maven 插件版本。

我读过“maven 方式”,在我看来这是对这种方式的违反——强制版本而不是从 superpom 继承它们。这是我们在项目 pom 中的示例:

    <build>
        <plugins>
            <plugin>
                <artifactId>maven-compiler-plugin</artifactId>
                <version>2.3.2</version>
                <configuration>...</configuration>
            </plugin>

我的问题是 - 强制使用这样的插件版本的正当理由(如果有的话)是什么。我想知道,因为我经常发现编写的代码没有任何明确的目的,我确实想知道是否属于这种情况,以及我是否应该从项目根 pom 中删除该版本。

事后思考:关于这个site他们说:

When declaring a "normal" version such as 3.8.2 for Junit, internally this is represented as "allow anything, but prefer 3.8.2." This means that when a conflict is detected, Maven is allowed to use the conflict algorithms to choose the best version. If you specify [3.8.2], it means that only 3.8.2 will be used and nothing else.

所以这意味着,如果你强制版本以确保稳定性,那么你也应该使用 [] 否则 maven 可以随意忽略你的强制版本。

最佳答案

最好的办法是只在公司 pom 中定义插件版本,当然要随时维护这个公司 pom,这意味着要不时更新插件版本。

这意味着在其他项目中不需要或最好避免使用不同版本的插件(除非有很好的理由在插件中出现此错误)。

此外,您提供的摘录是不良做法的示例,导致插件和/或其配置应改用 pluginManagement 来定义。

因此,如果一个项目需要旧版本的 Maven 插件,则至少应该在 pom 中有一条注释,说明为什么它使用的不是继承的版本。可能带有指向相应 JIRA 问题的链接...

关于java - 强制使用旧 Maven 插件版本的任何正当理由?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28525461/

相关文章:

java - 在我的应用程序中显示站点和 Facebook 的帖子

maven - 是否有从 Maven pom 中删除旧依赖项的最佳实践?

java - 将 Spring boot war 部署到 Tomcat 8

java - 如何在maven插件中初始化/运行java项目

css - 我如何改变谷歌的 polymer 元素纸元素的大小?

java - 在 Android 应用程序中集成 microsoft MIP sdk 时面临问题

java - Bufferedreader 和文件路径 - 简单

java - 从java在mysql中从root创建其他用户

maven - 为什么在尝试使用 Grails Release 插件中的 publish-plugin 时得到 400

git - 如何在 CMake 中使其可执行之前检查文件是否存在