我想在每次生成时同步两个存储库,我已经看过这个脚本,但是我不知道如何用凭据设置远程分支。
# clone the reposotory
git clone --bare $ORIGIN_URL
# add a remote repository
cd $REPO_NAME
git remote add --mirror=fetch repo1 $REPO1_URL
# update the local copy from the first repository
git fetch origin --tags
# update the local copy with the second repository
git fetch repo1 --tags
# sync back the 2 repositories
git push origin --all
git push origin --tags
git push repo1 --all
git push repo1 --tags
管道:
node('centos-small') {
sh 'git config --global user.email "[email protected]"'
sh 'git config --global user.name "ci-bot"'
git credentialsId: 'JenkinsGit', url: 'git url'
}
我不知道如何设置凭据以将更改推送到远程repo。
Git推送回购1——全部
git push repo1——标记
最佳答案
当某个东西被推到第一个回购协议时(通过webhook或类似的方式),应该会触发此操作。
node('centos-small') {
stage('Set Git Config'){
sh 'git config --global user.email "[email protected]"'
sh 'git config --global user.name "ci-bot"'
sh 'git config --global credential.helper cache'
sh "git config --global credential.helper 'cache --timeout=3600'"
}
stage('Set Git Credentials'){
git credentialsId: 'JenkinsGit', url: '${TFS_REPO}'
git credentialsId: 'Second', url: '${SECOND_REPO}'
}
stage('Syncronize TFS-SECOND'){
sh 'git clone --bare ${TFS_REPO} tfs'
dir("tfs") {
//add a remote repository
sh 'git remote add --mirror=fetch second ${SECOND_REPO}'
// update the local copy from the first repository
sh 'git fetch origin --tags'
// update the local copy with the second repository
sh 'git fetch second --tags'
// sync back the second repository
sh 'git push second --all'
sh 'git push second --tags'
}
}
}