为 Adobe 存储库提供的 Git 子模块支持 git-submodule-support
Git 子模块可用于在构建时跨 Git 存储库合并多个分支的内容。
当运行 Cloud Manager 的构建过程时,它首先会克隆管道的存储库并签出已配置的分支。 如果该分支的根目录中包含 .gitmodules
文件,则执行该命令。
$ git submodule update --init
该过程会将每个子模块签入相应的目录中。 对于能够轻松使用 Git 子模块并且不想管理外部合并过程的组织来说,此方法是使用多个源 Git 存储库的潜在替代方法。
例如,假设有三个存储库,每个存储库均包含一个名为 main
的分支。 在“主”存储库(即,在管道中配置的存储库)中,main
分支包含一个 pom.xml
文件,声明其他两个存储库所包含的项目:
<?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>customer.group.id</groupId>
<artifactId>customer-reactor</artifactId>
<version>0.0.1-SNAPSHOT</version>
<packaging>pom</packaging>
<modules>
<module>project-a</module>
<module>project-b</module>
</modules>
</project>
之后为其他两个存储库添加子模块:
$ git submodule add -b main https://git.cloudmanager.adobe.com/ProgramName/projectA/ project-a
$ git submodule add -b main https://git.cloudmanager.adobe.com/ProgramName/projectB/ project-b
.gitmodules
文件中的结果如下所示:
[submodule "project-a"]
path = project-a
url = https://git.cloudmanager.adobe.com/ProgramName/projectA/
branch = main
[submodule "project-b"]
path = project-b
url = https://git.cloudmanager.adobe.com/ProgramName/projectB/
branch = main
请参阅 Git 参考手册,了解有关 Git 子模块的更多信息。
限制 limitations
使用 Git 子模块时,请注意以下:
- Git URL 必须完全遵循上述语法。
- 为安全起见,请勿在这些 URL 中嵌入凭据。
- 仅支持分支的根目录中的子模块。
- Git 子模块引用将存储到特定的 Git 承诺中。 因此,在对子模块存储库进行更改时,需要更新引用的承诺。 例如,通过使用
git submodule update --remote
。 - 除非另有必要,Adobe 建议您通过为每个子模块运行
git config -f .gitmodules submodule.<submodule path>.shallow true
来使用“浅”子模块。
Git 子模块对专用存储库的支持 private-repositories
使用专用存储库时对 Git 子模块的支持与使用 Adobe 存储库时大致相同。
然而,在设置您的 pom.xml
文件并运行 git submodule
命令之后,您必须添加 .gitmodules
文件复制到聚合器存储库的根目录,以便 Cloud Manager 检测子模块设置。
限制和建议 limitations-recommendations-private-repos
使用带有专用存储库的 Git 子模块时,注意以下限制。
- 子模块的 Git URL 可以是 HTTPS 或 SSH 格式,但必须链接到 Github.com 存储库。 将 Adobe 存储库子模块添加到 GitHub 聚合器存储库或反之亦然不起作用。
- GitHub 子模块必须可供 Adobe GitHub App 访问。
- 使用 Git 子模块与 Adobe 管理的存储库的局限性同样适用。
recommendation-more-help
c6cdc82b-cee9-48e0-a6ee-48149d5e72c3