用 Gitlab CI/CD 在 gitlab 私服仓库发布 maven 包,为什么子项目 pom 文件里的<repositories>属性没有继承父项目

2023-07-19 16:58:28 +08:00
 Emilyan

我有一个父项目 XX-parent, 子项目 xx-commonlib 要用流水线发布到公司的 gitlab 私服,script 命令 mvn deploy -s ci_settings.xml

父项目的 pom 中添加了仓库和部署仓库的地址

<repositories>
    <repository>
        <id>gitlab-maven</id>
        <url>https://sample-gitlab/api/v4/projects/20/packages/maven</url>
    </repository>
</repositories>
<distributionManagement>
    <repository>
        <id>gitlab-maven</id>
        <url>https://sample-gitlab/api/v4/projects/20/packages/maven</url>
    </repository>
    <snapshotRepository>
        <id>gitlab-maven</id>
        <url>https://sample-gitlab/api/v4/projects/20/packages/maven</url>
    </snapshotRepository>
</distributionManagement>

子项目 xx-commonlib 的 pom 中继承父项目,没有添加相关仓库的配置

<parent> <groupId>xx.xx.xx</groupId> <artifactId>xx-parent</artifactId> <version>1.0.0-SNAPSHOT</version> <relativePath/> </parent>

向 gitlab 推送代码,CI/CD 自动发布后,父项目 xx-parent 可以正常发布到 gitlab 的 maven 私服仓库上,子项目 xx-commonlib 报错

Non-resolvable parent POM for xx.xx.xx:xx-commonlib:1.0.0-SNAPSHOT: Could not find artifact xx.xx.xx:xx-parent:pom:1.0.0-SNAPSHOT and 'parent.relativePath' points at no local POM @ line 6, column 13

必须在子项目 xx-commonlib 的 pom 中添加

<repositories> <repository> <id>gitlab-maven</id> <url>https://sample-gitlab/api/v4/projects/20/packages/maven</url> </repository> </repositories>

后子项目才可以正常发布到仓库。

我的疑问是为什么子项目没有继承父项目的<repositories>仓库配置,但是可以继承<distributionManagement>部署仓库配置。 因为这个父项目下面有不少子项目,如果每个子项目的 pom 文件里都要写一遍 repositories 地址的话可能比较麻烦。

stackflow 上有个类似的问题,好像没有正确的答案 https://stackoverflow.com/questions/69570730/maven-child-modules-not-inheriting-repository-tags

1187 次点击
所在节点    Java
9 条回复
vantis
2023-07-19 21:49:31 +08:00
子项目的 parent.relativePath 配对了吗 这个报错应该是没找到父项目 自然无从继承
所以首先要通过相对路径找到本地的父项目 才能继承父项目的配置
Emilyan
2023-07-20 09:32:18 +08:00
@vantis
就是<relativePath/>
强制从仓库里寻找父项目
vantis
2023-07-20 21:42:36 +08:00
@Emilyan #2 不设置 relativePath 子项目就强制去仓库里找项目——这时的仓库是谁呢?因为本配置没有 父级又找不到 自然是用你机器上的 settings 配置了
所以应该指定 relativePath 为../pom.xml 让子项目先根据相对路径去找到父级 就能继承父级的配置了 repositories, distributionManagement 等等配置也会继承到
vantis
2023-07-20 21:43:23 +08:00
可以参考
https://www.baeldung.com/maven-relativepath
baeldung 的文章质量不错的
Emilyan
2023-07-21 10:18:15 +08:00
@vantis 谢谢热心回复,测试了一下还是'parent.relativePath' points at no local POM 错误。
这是把 maven 包 deploy 到 Gitlab-CI 发布到公司私服,不是我机器上。而且在设置<relativePath>为空的情况下,
<distributionManagement>是成功继承的,就是继承不了<repositories>配置
vantis
2023-07-22 09:28:49 +08:00
@Emilyan #5 子项目不是随父项目一起打包的吗?如果是通过父项目下执行 mvn deploy 没有特殊配置的话 父子项目都会 deploy 的
我是不是可以理解你拆成两个项目了?
Emilyan
2023-07-24 09:42:44 +08:00
@vantis 确实是拆成两个项目,路径上是平级的。父项目只是做依赖管理。
ikas
2023-07-29 09:24:28 +08:00
你是在子项目运行 mvn 命令的吧...
Emilyan
2023-07-31 10:03:45 +08:00
@ikas 是的,但是父项目已经发布到 gitlab package registry 仓库了啊

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/958048

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX