Git 201 - Git Repo Sync

–bare

1
2
3
4
5
6
7
8
Make a bare Git repository. That is, instead of creating <directory>
and placing the administrative files in <directory>/.git,
make the <directory> itself the $GIT_DIR. This obviously implies the -n
because there is nowhere to check out the working tree.
Also the branch heads at the remote are copied directly to corresponding
local branch heads, without mapping them to refs/remotes/origin/.
When this option is used, neither remote-tracking branches nor the
related configuration variables are created.

–mirror

1
2
3
4
5
6
Set up a mirror of the source repository. This implies --bare.
Compared to --bare, --mirror not only maps local branches of the
source to local branches of the target, it maps all refs
(including remote-tracking branches, notes etc.) and sets up a
refspec configuration such that all these refs are overwritten
by a git remote update in the target repository.

–bare参数和–mirror参数创建的克隆版本库都不包含工作区,直接就是版本库的内容,这样的版本库称为裸版本库。一般约定俗成裸版本库的目录名以.git做后缀,所以上面示例中将克隆出来的裸版本库目录名写作。区别在于–mirror参数克隆出来的裸版本对上游版本库进行了注册,这样可以在裸版本库中使用git fetch命令和上游版本库进行持续同步。
不使用—bare或—mirror创建出来的克隆包含工作区,这样就会产生两个包含工作区的版本库,这两个版本库对等。这两个工作区本质上没有区别,往往提交在一个版本A中进行,另一个B作为备份。只能从B执行git pull命令从A中拉回新的提交实现版本库同步,而不能从版本库A向版本库B执行git push推送操作。
还可以通过git init的方式创建裸版本库,需要加—bare参数。
当执行git push命令时,如果没有设定推送的分支,而且当前分支也没有注册到远程的某个分支,将检查远程分支是否有和本地相同的分支名(如master),如果有,则推送,否则报错。

REF::