了解如何在使用 Cloud Manager 時管理多個 Git 存放庫。
客戶可以使用自己的 Git 存放庫或多個自己的 Git 存放庫,而不是直接使用 Cloud Manager 的 Git 存放庫。在這些情況下,應設定自動同步流程,以確保Cloud Manager的Git存放庫隨時保持最新。
根據託管客戶 Git 存放庫的位置,可以使用 GitHub 操作或 Jenkins 等持續整合解決方案來設定自動化。建立自動化後,可將每次到客戶自己的Git存放庫的推送自動轉寄到Cloud Manager的Git存放庫。
雖然對單一客戶擁有的 Git 存放庫而言,這類自動化很簡單,但若為多個存放庫設定,則需要初始設定。來自多個Git存放庫的內容必須對應到單一Cloud Manager的Git存放庫中不同的目錄。 Cloud Manager的Git存放庫必須布建根Maven pom.xml
,在模組區段中列出不同的子專案。
以下是兩個客戶自有 Git 存放庫的範例 pom.xml
檔案。
project-a
的目錄中。project-b
的目錄中。<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="https://maven.apache.org/POM/4.0.0" xmlns:xsi="https://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="https://maven.apache.org/POM/4.0.0 https://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>
這類根 pom.xml
會被推送到 Cloud Manager 的 Git 存放庫中的某個分支。然後必須設定這兩個專案以自動將變更轉寄到Cloud Manager的Git存放庫。
以下是可能的解決方案。
project-a
在Cloud Manager的Git存放庫中。例如,會將專案 A 中主要分支上的變更自動推送到 Cloud Manager 的 Git 存放庫中的主要分支。分支之間可能存在對應,例如推送到名為的分支 dev
在專案A中,會推送至名為的分支 development
在Cloud Manager的Git存放庫中。 專案 B 需要類似的步驟。
根據分支原則和工作流程,可以為不同的分支設定同步。如果使用的Git存放庫不提供類似GitHub動作的概念,則也有可能透過Jenkins (或類似方法)進行整合。 在這種情況下,webhook 會觸發進行這項工作的 Jenkins 作業。
請按照以下步驟操作,以便您可以新增第三個來源或存放庫。
pom.xml
中新增對新目錄的參考資料。這是一個GitHub操作的範例,透過推送至主要分支然後推入Cloud Manager的Git存放庫的子目錄中來觸發。 GitHub動作必須提供兩個秘密: MAIN_USER
和 MAIN_PASSWORD
,以便能夠連線並推送至Cloud Manager的Git存放庫。
name: SYNC
env:
# Username/email used to commit to Cloud Manager's Git repository
USER_NAME: <NAME>
USER_EMAIL: <EMAIL>
# Directory within the Cloud Manager Git repository
PROJECT_DIR: project-a
# Cloud Manager's Git repository
MAIN_REPOSITORY: https://$MAIN_USER:$MAIN_PASSWORD@git.cloudmanager.adobe.com/<PATH>
# The branch in Cloud Manager's Git repository to push to
MAIN_BRANCH : <BRANCH_NAME>
# Only run on a push to this branch
on:
push:
branches: [ main ]
jobs:
build:
runs-on: ubuntu-latest
steps:
# Checkout this project into a sub folder
- uses: actions/checkout@v2
with:
path: sub
# Cleanup sub project
- name: Clean project
run: |
git -C sub log --format="%an : %s" -n 1 > commit.txt
rm -rf sub/.git
rm -rf sub/.github
# Set global git configuration
- name: Set git config
run: |
git config --global credential.helper cache
git config --global user.email ${USER_EMAIL}
git config --global user.name ${USER_NAME}
# Checkout the main project
- name: Checkout main project
run:
git clone -b ${MAIN_BRANCH} ${MAIN_REPOSITORY} ${MAIN_BRANCH}
# Move sub project
- name: Move project to main project
run: |
rm -rf ${MAIN_BRANCH}/${PROJECT_DIR}
mv sub ${MAIN_BRANCH}/${PROJECT_DIR}
- name: Commit Changes
run: |
git -C ${MAIN_BRANCH} add -f ${PROJECT_DIR}
git -C ${MAIN_BRANCH} commit -F ../commit.txt
git -C ${MAIN_BRANCH} push
使用GitHub動作相當靈活。 可執行 Git 存放庫分支之間的任何對應,以及單獨 Git 專案至主要專案目錄版面的任何對應。
範例指令碼使用 git add
來更新存放庫。這假設包括刪除。根據Git的預設設定,這必須替換為 git add --all
.
這是指令碼範例,可用於 Jenkins 作業或類似操作,流程如下所示:
Jenkins作業必須提供兩個秘密: MAIN_USER
和 MAIN_PASSWORD
,以便能夠連線並推送至Cloud Manager的Git存放庫。
# Username/email used to commit to Cloud Manager's Git repository
export USER_NAME=<NAME>
export USER_EMAIL=<EMAIL>
# Directory within the Cloud Manager Git repository
export PROJECT_DIR=project-a
# Cloud Manager's Git repository
export MAIN_REPOSITORY=https://$MAIN_USER:$MAIN_PASSWORD@git.cloudmanager.adobe.com/<PATH>
# The branch in Cloud Manager's Git repository to push to
export MAIN_BRANCH=<BRANCH_NAME>
# clean up and init
rm -rf target
mkdir target
# mv project to sub folder
mkdir target/sub
for f in .* *
do
if [ "$f" != "." -a "$f" != ".." -a "$f" != "target" ]
then
mv "$f" target/sub
fi
done
cd target
# capture log and remove git info
cd sub
git log --format="%an : %s" -n 1 > ../commit.txt
rm -rf .git
rm -rf .github
cd ..
# checkout main repository
git clone -b $MAIN_BRANCH $MAIN_REPOSITORY main
cd main
# configure main repository
git config credential.helper cache
git config user.email $USER_EMAIL
git config user.name $USER_NAME
# update project in main
rm -rf $PROJECT_DIR
mv ../sub $PROJECT_DIR
# commit changes to main
git add -f $PROJECT_DIR
git commit -F ../commit.txt
git push
使用Jenkins作業是靈活的。 可執行 Git 存放庫分支之間的任何對應,以及單獨 Git 專案至主要專案目錄版面的任何對應。
範例指令碼使用 git add
來更新存放庫。這假設包括刪除。根據Git的預設設定,這必須替換為 git add --all
.