Artifactory/JFrog在生成的POM中生成错误的父项artifactId
在尝试将新版本构建部署到我公司的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.jar
和berry-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.nbyrd:berries:jar:1.0的POM无效,传递依赖(如果有的话)将不可用,启用用于上传到artifactory的时候到过去正常工作的详细信息
此功能的调试日志记录,所以我不知道如果事情如何改变该工具的工作原理,或者如果我只是做了错误的事情。有什么想法吗?
当您使用mvn deploy
时,maven将pom.xml
文件作为分离的工件进行部署。但是当你用artifactory的web ui上传jar文件并且要求artifactory生成pom文件时,我想它会从jar中的数据中产生它。所以Artifactory不知道父项目的存在。
你是什么意思'我会上传这些工件到Artifactory,以便其他项目可以引用它们。这是否意味着您已手动上传它们?或者通过'mvn deploy'使用过你的Maven构建版本? – khmarbaise
@khmarbaise我通过登录到jfrog.io来上传它们,并通过我的浏览器将工件上传到相应的回购站。我以前没有尝试过使用'mvn deploy'。 – nasukkin
@khmarbaise感谢您提出'mvn deploy'。我使用'distributionManagement'设置了我的项目,并给它一个旋转,现在工件被正确部署。所以,至少我是畅通无阻的,但我仍然想知道为什么它会成为webapp版本部署的问题。 – nasukkin