你的过程几乎是完美的。唯一的问题是--mirror
初始克隆上缺少一个参数。
# create the private repo
ssh private-server
mkdir -p /path/to/shared/repos
git init --shared={whatever makes sense for your environment} /path/to/shared/repos/internalrepo.git
exit
# go to github.com and make the public repo readonly
# create a local mirror
git clone --bare --mirror $Github-URL github.git
# now the local repo github.git contains all the stuff from the github repo
cd github.git
git push --mirror $Private-URL
# Tell all developers to execute `git remote set-url origin $Private-URL`
# Done
我不会让 github 存储库对更改开放,因为项目中的每个人都不清楚哪个存储库现在是正确的存储库。如果您在 server-repo 上运行,您仍然可以这样做
ssh private-server
cd /path/to/shared/repos/internalrepo.git
git remote add --mirror github $Github-URL
然后定期(例如在 cron 工作中)
git fetch github # get new commits from github
git remote prune github # drop branches, which are now deleted in the github repo
编辑
您也可以使用本地镜像进行交换。但是没有简单的自动化过程,因为 git 既不能决定如何处理已删除的分支,也不能决定如何处理分歧的分支。所以你需要保留一个工作存储库,定期从以前的 github-repo 获取东西,从内部 repo 获取东西,解决不同的历史并将这些东西推回内部 repo。