Maven 部署到快照而不是发布
Posted
技术标签:
【中文标题】Maven 部署到快照而不是发布【英文标题】:Maven deploys to snapshot instead of release 【发布时间】:2011-11-12 01:16:06 【问题描述】:我正在尝试使用 maven 发布一个项目,但不是发布到 Releases 存储库,而是将它放在我们的 Snapshots 存储库中。
我的 pom 看起来像:
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0
http://maven.apache.org/maven-v4_0_0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>com.example.my.profiler</groupId>
<artifactId>profilerlib</artifactId>
<name>Profiler Lib</name>
<version>1.0.2-SNAPSHOT</version>
<description>Profiler Library</description>
<scm>
<connection>scm:svn:https://svn.example.com/my-project/profilerlib/trunk
</connection>
<developerConnection>scm:svn:https://svn.example.com/my-project/profilerlib/trunk
</developerConnection>
</scm>
<distributionManagement>
<!-- Publish the versioned releases here -->
<repository>
<id>nexus</id>
<name>nexus</name>
<url>http://repo.example.com:8081/nexus/content/repositories/releases
</url>
</repository>
<!-- Publish the versioned releases here -->
<snapshotRepository>
<id>nexus</id>
<name>nexus</name>
<url>http://repo.example.com:8081/nexus/content/repositories/snapshots
</url>
</snapshotRepository>
</distributionManagement>
<!-- download artifacts from this repo -->
<repositories>
<repository>
<id>nexus</id>
<name>EXAMPLE Public Repository</name>
<url>http://repo.example.com:8081/nexus/content/groups/public</url>
<releases>
<enabled>true</enabled>
</releases>
<snapshots>
<enabled>true</enabled>
</snapshots>
</repository>
</repositories>
<dependencies>
...
</dependencies>
<build>
<finalName>$project.artifactId</finalName>
<plugins>
<plugin>
<artifactId>maven-release-plugin</artifactId>
<configuration>
<tagBase>https://svn.example.com/my-project/profilerlib/tags
</tagBase>
</configuration>
</plugin>
<plugin>
<artifactId>maven-compiler-plugin</artifactId>
<configuration>
<source>1.6</source>
<target>1.6</target>
</configuration>
</plugin>
</plugins>
</build>
<properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<powermock.version>1.4.6</powermock.version>
</properties>
</project>
【问题讨论】:
你找到解决这个问题的方法了吗? 很久以前,但是 IIRC 我必须在我的 pom.xml 中定义单独的存储库和 snapShotRepository ID 值。 【参考方案1】:如果其他人遇到此问题并找到现有答案并不能解决他们的问题:
有一些错误意味着release:prepare
在创建发布标签之前不会提交到 git 存储库。这意味着release:perform
找到的pom 文件中的版本号包含-SNAPSHOT
,并且部署者将尝试发布到快照存储库。
这是导致此行为的最新缺陷:MRELEASE-875(影响 2.5,已在 2.5.1 中修复)
【讨论】:
这正是我的问题,谢谢!出于某种原因,Maven 选择了损坏的 2.5 版本;通过在 POM 中指定版本来强制它选择 2.5.1 (mvnrepository.com/artifact/org.apache.maven.plugins/…)。 确认一下!非常感谢。我发现an help page 显示2.5
版本的maven-release-plugin
。我只是在ML 上发送电子邮件,要求他们更新此页面。【参考方案2】:
<repository>
<id>nexus</id><!--etc-->
</repository>
<snapshotRepository>
<id>nexus</id><!--etc-->
</snapshotRepository>
<!-- etc -->
<repositories>
<repository>
<id>nexus</id>
<!-- etc -->
</repository>
</repositories>
这是问题所在,您对三个不同的存储库使用相同的 id。 Maven 通过 ID 管理这些存储库,因此每个 ID 必须是唯一的!例如。使用“nexus-releases”、“nexus-snapshots”和“nexus”。
【讨论】:
感谢您的提示,我试过了,但仍然遇到同样的问题。完整的 Maven 输出会有帮助吗? 如果它没有解决问题,为什么这是公认的答案? @Ken 两个答案都是有效的,它们只是显示了问题可能的两个不同方面。也许两者一起解决了问题?【参考方案3】:POM 显示版本号为 SNAPSHOT 版本。因此,如果您在 POM 处于此状态时运行 mvn deploy
,它自然会将快照部署到快照存储库。
要发布,您需要使用release plugin 的目标。
另一方面,也许您已经知道这一点,而真正的答案就在肖恩·帕特里克·弗洛伊德的回答中。
【讨论】:
哈哈,我忽略了明显的(+1)!! 我正在运行:mvn release:prepare release:perform NOT mvn deploy。据我了解,发布插件应该在部署之前删除 -SNAPSHOT 后缀,不是吗? @user932509 你应该在两个单独的步骤中运行准备和执行,因为我怀疑准备会改变正在运行的执行工件的版本(那将是邪恶的) 也单独运行。同样的问题。根据这个准备确实改变了版本:***.com/questions/810957/…【参考方案4】:由于不同的原因遇到了这个问题......确保发布插件正在检查一个标签,而不是一个同名的分支!
我刚刚犯了这个错误...我创建了一个名为“1.9.0”的分支来执行我的发布,然后运行 mvn release:prepare 它也创建了一个“1.9.0”标签。当 mvn release:perform 运行时,它执行了“1.9.0”的 git checkout,并最终选择了 1.9.0 分支的 HEAD,其中当然有一个 SNAPSHOT(1.10-SNAPSHOT)。
那是我生命中的两个小时,我不会再回来了……将来我会在分支名称中添加一个“-release”后缀(例如“1.9.0-release”)。
【讨论】:
【参考方案5】:如果问题仍然存在,它们可能与您在父 pom.xml 中指定的 maven-release-plugin 版本有关。指定 maven-release-plugin 的 2.2.2 肯定会失败,并且只会部署快照(在某些条件下尚未完全解释)。最新的插件(即从 pom.xml 中删除标签)仍然有效。
【讨论】:
以上是关于Maven 部署到快照而不是发布的主要内容,如果未能解决你的问题,请参考以下文章
maven发布项目到私服-snapshot快照库和release发布库的区别和作用及maven常用命令
maven中snapshot快照库和release发布库的区别和作用