设置Maven以允许轻松部署到不同的存储库

时间:2013-05-02 14:27:37

标签: maven deployment maven-3

我目前正在一个为很多人定义规则的环境中工作。我们目前使用Hudson和Artifactory,我想评估切换到Jenkins和Nexus是否值得迁移成本(但这不是问题)。

为了评估它,我在本地设置了Maven,Jenkins和Nexus,我尝试找到一个设置来使用之前的设置,以便我可以比较解决方案。这里的问题是:

  • 当我使用现有的POM并通过Jenkins构建和部署它时,它会自动部署到我们的旧环境中。
  • 然后我尝试在Maven的deploymentManagement文件中定义.settings部分,但这是不允许的(请参阅Configuring Maven

      

    注意:安装和用户配置不能用于添加共享项目信息 - 例如,设置或公司范围。

  • 我当然可以复制整个,并更改每个POM中的distributionManagement,但我想在不同的安装中使用相同的(不是复制的)示例。

我们当前的根POM包含以下部分:

<distributionManagement>
    <repository>
      <uniqueVersion>false</uniqueVersion>
      <id>company-central</id>
      <name>Company central maven respository</name>
      <url>https://company.com/artifactory/libs-releases</url>
    </repository>
    <snapshotRepository>
      <id>company-snaps</id>
      <name>company-snapshots</name>
      <url>https://company.com/artifactory/libs-snapshots</url>
    </snapshotRepository>
    <downloadUrl>https://company.com/artifactory/libs-releases</downloadUrl>
  </distributionManagement>

使用相同POM的最简单方法是什么,但将其部署到不同的存储库管理器?

PS:我读过set up maven pom file for different deployment scenarios并且不喜欢它(在我的上下文中),Deploying Maven artifact to multiple repositories with different settings实际上是一个不同的问题。 Multiple deployments in maven是一种有趣的方法,但我只能为此目的修改很多POM。

1 个答案:

答案 0 :(得分:15)

我是一个类似的团队,为他人提供工具。我们的父POM (不是settings.xml)设置如下所示。除非我的团队成员之一将-DuseTestRepo=true添加到mvn命令行,否则prod版本处于活动状态。您可以尝试更改激活以查找仅存在于Jenkins服务器上的特定文件(例如)。我也想知道Maven是否在repo URL中插入属性。如果是,您可以在settings.xml中执行<url>${my.remote.repo}/releases</url>并定义my.remote.repo。没试过那个。

<profiles>
    <profile>
        <id>test-repository</id>
        <activation>
            <property>
                <name>useTestRepo</name>
                <value>true</value>
            </property>
        </activation>
        <properties>
        </properties>
        <distributionManagement>
            <repository>
                 <!-- ... -->
            </repository>
            <snapshotRepository>
                 <!-- ... -->
            </snapshotRepository>
        </distributionManagement>
    </profile>

    <profile>
        <id>prod-repository</id>
        <activation>
            <property>
                <name>!useTestRepo</name>
            </property>
        </activation>
        <properties>
        </properties>
        <distributionManagement>
            <repository>
                 <!-- ... -->
            </repository>
            <snapshotRepository>
                 <!-- ... -->
            </snapshotRepository>
        </distributionManagement>
    </profile>

关于交付(部署)您的实验性父POM - 您将把它部署到您的测试Nexus回购中,对吧?而且你的开发人员都没有访问过它。因此Artifactory将包含真实的com.company:corporate-parent:1.0 POM,而Nexus包含com.company:corporate-parent:1.0,其中包含您进行测试所需的更改。

我还会考虑更改settings.xml中的本地仓库,这样就不会混合来自两个远程仓库的工件。