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-部署jar的发布版本

Jenkins Maven 发布:替换快照依赖

maven发布项目到私服-snapshot快照库和release发布库的区别和作用及maven常用命令

maven中snapshot快照库和release发布库的区别和作用

我可以将 Maven 配置为使用快照版本的自定义内部版本号吗

快照/发布:Maven 项目的版本控制策略