在Maven中,依赖关系通常是这样设置的:
<dependency>
<groupId>wonderful-inc</groupId>
<artifactId>dream-library</artifactId>
<version>1.2.3</version>
</dependency>
现在,如果您使用的是频繁发布的库,那么不断更新<version>标记可能会有些烦人。有没有办法告诉Maven始终使用最新的可用版本(来自存储库)?
在Maven中,依赖关系通常是这样设置的:
<dependency>
<groupId>wonderful-inc</groupId>
<artifactId>dream-library</artifactId>
<version>1.2.3</version>
</dependency>
现在,如果您使用的是频繁发布的库,那么不断更新<version>标记可能会有些烦人。有没有办法告诉Maven始终使用最新的可用版本(来自存储库)?
当前回答
与其他人不同,我认为有很多原因可以解释为什么你总是想要最新版本。特别是如果您正在进行连续部署(我们有时一天会发布5个版本),并且不想进行多模块项目。
我所做的是让Hudson/Jenkins为每个构建执行以下操作:
mvn clean versions:use-latest-versions scm:checkin deploy -Dmessage="update versions" -DperformRelease=true
也就是说,我使用版本插件和scm插件来更新依赖项,然后将其签入源代码管理。是的,我让我的CI进行SCM签入(对于maven发布插件,无论如何都必须这样做)。
您需要设置版本插件以仅更新您想要的内容:
<plugin>
<groupId>org.codehaus.mojo</groupId>
<artifactId>versions-maven-plugin</artifactId>
<version>1.2</version>
<configuration>
<includesList>com.snaphop</includesList>
<generateBackupPoms>false</generateBackupPoms>
<allowSnapshots>true</allowSnapshots>
</configuration>
</plugin>
我使用发布插件来进行发布,该插件负责-SNAPSHOT,并验证是否存在-SNAPSHO的发布版本(这很重要)。
如果您执行我所做的操作,您将获得所有快照版本的最新版本和发布版本的最新版。您的构建也将是可复制的。
使现代化
我注意到一些评论询问了此工作流的一些细节。我会说,我们不再使用这种方法了,maven版本插件存在缺陷的主要原因是它本身就存在缺陷。
这是有缺陷的,因为要运行版本插件来调整版本,pom需要存在所有现有版本才能正确运行。也就是说,如果找不到pom中引用的版本,版本插件就无法更新到最新版本。这实际上相当令人讨厌,因为我们经常因为磁盘空间的原因清理旧版本。
实际上,您需要一个独立于maven的工具来调整版本(因此您不需要依赖pom文件才能正确运行)。我用低级语言Bash编写了这样一个工具。该脚本将像版本插件一样更新版本,并将pom检查回源代码管理。它的运行速度也比mvn版本插件快100倍。不幸的是,它不是以公共使用的方式编写的,但如果人们感兴趣,我可以这样做,并将其放入要旨或github中。
当一些评论问及我们的工作时,返回工作流:
我们有大约20个项目在他们自己的存储库中,他们有自己的jenkins工作当我们发布maven发布插件时,将使用该插件。该插件的文档中介绍了其工作流程。maven发布插件有点糟糕(我很友好),但它确实有效。有一天,我们计划用更优化的方法来替代这种方法。当其中一个项目发布后,jenkins会运行一个特殊的作业,我们称之为更新所有版本作业(jenkins如何知道它的发布是一个复杂的方式,部分原因是maven jenkins发布插件也很糟糕)。更新所有版本作业了解所有20个项目。它实际上是一个聚合器pom,以依赖关系顺序特定于模块部分中的所有项目。Jenkins运行我们神奇的groovy/bash-foo,它会将所有项目更新到最新版本,然后签入pom(同样是基于模块部分的依赖顺序)。对于每个项目,如果pom发生了更改(由于某些依赖项的版本更改),它将被检入,然后我们立即ping jenkins为该项目运行相应的作业(这是为了保持构建依赖项顺序,否则您将受到SCM轮询调度程序的支配)。
在这一点上,我认为无论如何,将发布和自动版本作为一个独立于常规构建的工具是一件好事。
现在您可能会认为maven有点糟糕,因为上面列出的问题,但对于没有声明性易于解析的可扩展语法(也称为XML)的构建工具来说,这实际上相当困难。
事实上,我们通过命名空间添加自定义XML属性来帮助提示bash/groovy脚本(例如,不要更新此版本)。
其他回答
您是否可能依赖于在开发过程中明显变化很大的开发版本?
不增加开发版本的版本,您可以只使用快照版本,在必要时覆盖快照版本,这意味着您不必在每次微小更改时更改版本标记。类似于1.0-SNAPSHOT。。。
但也许你正在尝试实现其他目标;)
使用过最新快照的用户,请确保您有-U,否则将无法获取最新快照。
mvn -U dependency:copy -Dartifact=com.foo:my-foo:LATEST
// pull the latest snapshot for my-foo from all repositories
现在我知道这个话题已经过时了,但是阅读这个问题和OP提供的答案,Maven版本插件实际上可能是对他的问题的更好答案:
特别是以下目标可能有用:
版本:使用最新版本在pom中搜索所有版本其为较新版本将其替换为最新的版本版本:使用最新版本在pom中搜索所有非SNAPSHOT更新的版本释放并替换为最新版本。版本:更新属性更新在中定义的财产项目,使其与的最新可用版本特定依赖关系。这可能是如果一组依赖项必须全部锁定到一个版本。
还提供了以下其他目标:
版本:显示相关性更新扫描项目的相关性和生成这些的报告具有更新版本的依赖项版本可用。版本:显示插件更新扫描项目的插件和生成这些插件的报告其具有可用的更新版本。版本:更新父项更新项目的父部分,以便它引用了最新的可用版本。例如,如果你使用的是企业根POM,这个如果你需要的话,这个目标会很有帮助确保您使用的是最新的企业根POM的版本。版本:更新子模块更新项目的子模块版本与当前项目。例如,如果您有一个聚合器pom它的项目的父级骨料和儿童以及父版本不同步,这mojo可以帮助修复子模块。(注意,您可能需要在中使用-N选项调用Maven如果您的这个项目被破坏得很厉害无法生成,因为版本不匹配)。版本:锁定快照在pom中搜索所有-SNAPSHOT版本,并将其替换为当前时间戳版本-快照,例如-20090327.172306-4版本:解锁快照在pom中搜索所有时间戳锁定的快照版本和替换他们用-SNAPSHOT。版本:解析范围使用版本范围和将范围解析为特定正在使用的版本。版本:使用releases在pom中搜索所有SNAPSHOT版本已发布并替换它们具有相应的版本版本版本:使用下一个版本在pom中搜索所有非SNAPSHOT更新的版本释放并替换为下一版本。版本:使用下一个版本在pom中搜索所有版本其为较新版本将其替换为下一版本。versions:commit删除pom.xml.versionsBackup文件。形式内置“穷人”的一半SCM”。版本:revert从pom.xml.versionsBackup文件。形式内置“穷人”的一半SCM”。
我只是想把它包括在内,以备将来参考。
请查看此页(“依赖项版本范围”部分)。你可能想做的是
<version>[1.2.3,)</version>
这些版本范围在Maven2中实现。
我在maven 3.5.4中的解决方案,在eclipse中使用nexus:
<dependency>
<groupId>yilin.sheng</groupId>
<artifactId>webspherecore</artifactId>
<version>LATEST</version>
</dependency>
然后在eclipse:atl+F5中,选择快照/发布的强制更新
这对我有用。