How to specify maven's distributionManagement organisation wide?

后端 未结 3 1279
青春惊慌失措
青春惊慌失措 2020-12-07 07:04

I\'m trying to figure out how to organize many (around 50+) maven2 projects, so that they can deploy into a central nexus repository. When using the mvn deploy

相关标签:
3条回答
  • 2020-12-07 07:44

    There's no need for a parent POM.

    You can omit the distributionManagement part entirely in your poms and set it either on your build server or in settings.xml.

    To do it on the build server, just pass to the mvn command:

    -DaltSnapshotDeploymentRepository=snapshots::default::https://YOUR_NEXUS_URL/snapshots
    -DaltReleaseDeploymentRepository=releases::default::https://YOUR_NEXUS_URL/releases
    

    See https://maven.apache.org/plugins/maven-deploy-plugin/deploy-mojo.html for details which options can be set.

    It's also possible to set this in your settings.xml.

    Just create a profile there which is enabled and contains the property.

    Example settings.xml:

    <settings>
    [...]
      <profiles>
        <profile>
          <id>nexus</id>
          <properties>
            <altSnapshotDeploymentRepository>snapshots::default::https://YOUR_NEXUS_URL/snapshots</altSnapshotDeploymentRepository>
            <altReleaseDeploymentRepository>releases::default::https://YOUR_NEXUS_URL/releases</altReleaseDeploymentRepository>
          </properties>
        </profile>
      </profiles>
    
      <activeProfiles>
        <activeProfile>nexus</activeProfile>
      </activeProfiles>
    
    </settings>
    

    Make sure that credentials for "snapshots" and "releases" are in the <servers> section of your settings.xml

    The properties altSnapshotDeploymentRepository and altReleaseDeploymentRepository are introduced with maven-deploy-plugin version 2.8. Older versions will fail with the error message

    Deployment failed: repository element was not specified in the POM inside distributionManagement element or in -DaltDeploymentRepository=id::layout::url parameter
    

    To fix this, you can enforce a newer version of the plug-in:

            <build>
              <pluginManagement>
                <plugins>
                  <plugin>
                    <artifactId>maven-deploy-plugin</artifactId>
                    <version>2.8</version>
                  </plugin>
                </plugins>
              </pluginManagement>
            </build>
    
    0 讨论(0)
  • 2020-12-07 07:49

    Regarding the answer from Michael Wyraz, where you use alt*DeploymentRepository in your settings.xml or command on the line, be careful if you are using version 3.0.0-M1 of the maven-deploy-plugin (which is the latest version at the time of writing), there is a bug in this version that could cause a server authentication issue.

    A workaround is as follows. In the value:

    releases::default::https://YOUR_NEXUS_URL/releases
    

    you need to remove the default section, making it:

    releases::https://YOUR_NEXUS_URL/releases
    

    The prior version 2.8.2 does not have this bug.

    0 讨论(0)
  • The best solution for this is to create a simple parent pom file project (with packaging 'pom') generically for all projects from your organization.

    <?xml version="1.0" encoding="UTF-8"?>
    <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>your.company</groupId>
        <artifactId>company-parent</artifactId>
        <version>1.0.0-SNAPSHOT</version>
        <packaging>pom</packaging>
    
        <distributionManagement>
            <repository>
                <id>nexus-site</id>
                <url>http://central_nexus/server</url>
            </repository>
        </distributionManagement>
    
    </project>
    

    This can be built, released, and deployed to your local nexus so everyone has access to its artifact.

    Now for all projects which you wish to use it, simply include this section:

    <parent>
      <groupId>your.company</groupId>
      <artifactId>company-parent</artifactId>
      <version>1.0.0</version>
    </parent>
    

    This solution will allow you to easily add other common things to all your company's projects. For instance if you wanted to standardize your JUnit usage to a specific version, this would be the perfect place for that.

    If you have projects that use multi-module structures that have their own parent, Maven also supports chaining inheritance so it is perfectly acceptable to make your project's parent pom file refer to your company's parent pom and have the project's child modules not even aware of your company's parent.

    I see from your example project structure that you are attempting to put your parent project at the same level as your aggregator pom. If your project needs its own parent, the best approach I have found is to include the parent at the same level as the rest of the modules and have your aggregator pom.xml file at the root of where all your modules' directories exist.

    - pom.xml (aggregator)
        - project-parent
        - project-module1
        - project-module2
    

    What you do with this structure is include your parent module in the aggregator and build everything with a mvn install from the root directory.

    We use this exact solution at my organization and it has stood the test of time and worked quite well for us.

    0 讨论(0)
提交回复
热议问题