2017-08-29 62 views
0

在尝试将新版本构建部署到我公司的JFrog.io(fka:ArtifactoryOnline.com)存储库时遇到了一个奇怪的错误。我正在开发的项目有多个Maven模块,都在单一父项下。当我将Maven构建的JAR文件上载到JFrog时,生成的POM文件正在填充不正确的父artifactId。Artifactory/JFrog在生成的POM中生成错误的父项artifactId

我花了很多时间,无法找到与我公司的项目代码相关的任何问题,所以我决定是否可以从头开始重现错误。因此我让this throwaway project来证明这个错误。对于那些下载完整的项目不感兴趣,这里有相关的POM文件:

父POM, “蓝莓”:

<?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/xsd/maven-4.0.0.xsd"> 
    <modelVersion>4.0.0</modelVersion> 

    <groupId>org.nbyrd</groupId> 
    <artifactId>blueberry</artifactId> 
    <packaging>pom</packaging> 
    <version>1.0</version> 
    <modules> 
     <module>blueberryjam</module> 
     <module>berries</module> 
    </modules> 
</project> 

相关POM 1: “浆果”:

<?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/xsd/maven-4.0.0.xsd"> 
    <parent> 
     <artifactId>blueberry</artifactId> 
     <groupId>org.nbyrd</groupId> 
     <version>1.0</version> 
    </parent> 
    <modelVersion>4.0.0</modelVersion> 

    <artifactId>berries</artifactId> 
    <build> 
     <plugins> 
      <plugin> 
       <groupId>org.apache.maven.plugins</groupId> 
       <artifactId>maven-compiler-plugin</artifactId> 
       <configuration> 
        <source>1.7</source> 
        <target>1.7</target> 
       </configuration> 
      </plugin> 
     </plugins> 
    </build> 
</project> 

相关POM 2,“浆果果酱”:

<?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/xsd/maven-4.0.0.xsd"> 
    <parent> 
     <artifactId>blueberry</artifactId> 
     <groupId>org.nbyrd</groupId> 
     <version>1.0</version> 
    </parent> 
    <modelVersion>4.0.0</modelVersion> 

    <artifactId>blueberry-jam</artifactId> 
    <dependencies> 
     <dependency> 
      <groupId>org.nbyrd</groupId> 
      <artifactId>berries</artifactId> 
      <version>1.0</version> 
     </dependency> 
    </dependencies> 
</project> 

(对于它的价值,所有这些POM文件是发电机密封在这一点上非常直接:我有两个Maven模块 - “浆果”和“浆果果酱” - 它们位于中央父模块“蓝莓”下面, 。浆果果酱使用浆果作为依赖,但我不确定这是否与问题有关。

当我构建项目时,我得到两个JAR文件:berries-1.0.jarberry-jam-1.0.jar。这是预期的。此时,我会将这些工件上传到Artifactory,以便其他项目可以引用它们。这是麻烦开始的地方。 当我上传berries-1.0.jar,Artifactory的生成以下POM文件:

<?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/xsd/maven-4.0.0.xsd"> 
    <parent> 
     <artifactId>berries</artifactId> 
     <groupId>org.nbyrd</groupId> 
     <version>1.0</version> 
    </parent> 
    <modelVersion>4.0.0</modelVersion> 

    <artifactId>berries</artifactId> 
    <build> 
     <plugins> 
      <plugin> 
       <groupId>org.apache.maven.plugins</groupId> 
       <artifactId>maven-compiler-plugin</artifactId> 
       <configuration> 
        <source>1.7</source> 
        <target>1.7</target> 
       </configuration> 
      </plugin> 
     </plugins> 
    </build> 
</project> 

正如你所看到的,所产生的POM父artifactId的定义为“浆果”,这是错误的。

<?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/xsd/maven-4.0.0.xsd"> 
    <parent> 
     <artifactId>blueberry-jam</artifactId> 
     <groupId>org.nbyrd</groupId> 
     <version>1.0</version> 
    </parent> 
    <modelVersion>4.0.0</modelVersion> 

    <artifactId>blueberry-jam</artifactId> 
    <dependencies> 
     <dependency> 
      <groupId>org.nbyrd</groupId> 
      <artifactId>berries</artifactId> 
      <version>1.0</version> 
     </dependency> 
    </dependencies> 
</project> 

在这两种情况下,我期望的parentId为“蓝莓”,因为它是在两个子模块POM文件中明确指出:当我上传berry-jam-1.0.jar发生 同样的问题。这些不正确的artifactIds使它不可能使用这些库。如果第三方应用程序试图使用这些库,maven将在下载依赖关系时产生以下警告,并且构建将失败:

[警告] org.nb​​yrd:berries:jar:1.0的POM无效,传递依赖(如果有的话)将不可用,启用用于上传到artifactory的时候到过去正常工作的详细信息

此功能的调试日志记录,所以我不知道如果事情如何改变该工具的工作原理,或者如果我只是做了错误的事情。有什么想法吗?

+0

你是什么意思'我会上传这些工件到Artifactory,以便其他项目可以引用它们。这是否意味着您已手动上传它们?或者通过'mvn deploy'使用过你的Maven构建版本? – khmarbaise

+0

@khmarbaise我通过登录到jfrog.io来上传它们,并通过我的浏览器将工件上传到相应的回购站。我以前没有尝试过使用'mvn deploy'。 – nasukkin

+0

@khmarbaise感谢您提出'mvn deploy'。我使用'distributionManagement'设置了我的项目,并给它一个旋转,现在工件被正确部署。所以,至少我是畅通无阻的,但我仍然想知道为什么它会成为webapp版本部署的问题。 – nasukkin

回答

1

当您使用mvn deploy时,maven将pom.xml文件作为分离的工件进行部署。但是当你用artifactory的web ui上传jar文件并且要求artifactory生成pom文件时,我想它会从jar中的数据中产生它。所以Artifactory不知道父项目的存在。