如何使用p2 maven插件有效管理第三方依赖关系



为了管理Eclipse RCP应用程序(与Tycho一起构建)中的第三方依赖关系,我正在使用p2 maven插件和Jetty将maven中心工件转换为捆绑包,并将其作为目标定义文件中的p2存储库使用。我的设置和工作流程如下:

  • 在p2 maven插件的工件部分添加依赖项
  • 运行目标p2:重建整个站点的站点
  • 运行码头
  • 重新加载目标
  • 现在,Manifest文件的依赖项部分提供了我的依赖项

所以我有3个问题:

  • 每次我想添加新的依赖项时,我都必须重建网站并重新启动Jetty,有没有一种方法可以通过添加pom中引用的新依赖项来更新存储库
  • 以下设置是否适用于拥有多个项目的公司:
    • 为每个项目创建一个(特定的第三方)远程P2存储库,并相应地配置项目的目标定义
    • 当团队成员想要第三方库时,他可以使用p2 maven插件生成捆绑包,将它们推送到远程存储库中,并清理pom的工件部分

最后,您如何管理团队中的第三方依赖关系?

  • 问题是,当您构建p2站点时,还会生成包含bundels信息的"context.xml"one_answers"artifact.xml"元数据。p2解析器用于解析捆绑包的这些元数据。因此,我认为如果不重建网站,更新p2回购将是一种困难的方式。

    我的建议是:自从你在团队中工作以来,最清晰的方法是为所有第三方依赖项(你可以使用类别.xml)建立一个独立的存储库(nexus、jetty、tomcat…)

    部署重新创建的p2并不是什么大不了的事,您可以在创建站点的同一pom中使用wagon-maven-plugin,并将其绑定到部署阶段,因此使用mvn clean deploy可以创建和部署存储库

示例:

<build>
<plugins>
    <plugin>
        <groupId>org.reficio</groupId>
        <artifactId>p2-maven-plugin</artifactId>
        <version>1.2.0-SNAPSHOT</version>
        <executions>
            <execution>
                <id>default-cli</id>
                <configuration>
                    <artifacts>
                        <!-- specify your depencies here -->
                        <!-- groupId:artifactId:version -->
                        <artifact><id>commons-io:commons-io:2.1</id></artifact>
                        <artifact><id>commons-lang:commons-lang:2.4</id></artifact>
                        <artifact><id>commons-lang:commons-lang:2.5</id></artifact>
                        <artifact><id>commons-lang:commons-lang:2.6</id></artifact>
                        <artifact><id>org.apache.commons:commons-lang3:3.1</id></artifact>
                    </artifacts>
                </configuration>
            </execution>
        </executions>
    </plugin>
    <plugin>
        <groupId>org.codehaus.mojo</groupId>
        <artifactId>wagon-maven-plugin</artifactId>
        <version>1.0</version>
        <executions>
            <execution>
                <id>upload-repo</id>
                <phase>deploy</phase>
                <goals>
                    <goal>upload</goal>
                </goals>
                <configuration>
                    <fromDir>${project.build.directory}/repository/</fromDir>
                    <includes>*/**</includes>
                    <serverId>my-p2-repository</serverId>
                    <url>dav:http://mycompany.com/../content/repositories</url>
                    <toDir>thirdparty-p2-repository</toDir>
                </configuration>
            </execution>
        </executions>
    </plugin>
</plugins>
<extensions>
    <extension>
        <groupId>org.apache.maven.wagon</groupId>
        <artifactId>wagon-webdav-jackrabbit</artifactId>
        <version>1.0-beta-7</version>
    </extension>
</extensions>

<distributionManagement>
        <repository>
            <id>my-p2-repository</id>
            <url>dav:http://mycompany.com/../content/repositories</url>
        </repository>
</distributionManagement>

注意:pom的distributionManagement部分中URL的ID需要与settings.xml文件中服务器部分的ID匹配。

在settings.xml:中添加服务器

<server>
 <id>my-p2-repository</id>
 <username>...</username>
 <password>...</password>
</server>

希望这能有所帮助。

最新更新