git 在同一个存储库上运行的多个实例是否会产生问题?

Do multiple instances of git operating on the same repository create problems?

我的雇主刚刚转git,所以我的同事们还是有些经验不足。他们现在的所作所为让我很担心,所以我把它写下来。

他们在一台机器上克隆了一个 git 存储库,然后通过 windows 共享共享该存储库。 现在,在存储库被共享到的机器上,他们在上面工作。 只要不超过一个人同时工作,这种方法的效果出奇地好。

还没有爆炸,但我有种不好的预感。

可能会出什么问题?或者这样做真的安全吗?

之前有人问: 他们这样做是因为共享目录上有他们不想复制到他们机器上的脚本。我试着说服他们放弃,但他们非常喜欢这个主意

如果他们所有来自这个共享区域,没关系。 (当有人更新共享区域时,他们必须全部停止阅读。)

写入共享区域通常不是一个好主意,因为:

  • 两个人可以尝试写入同一个文件;
  • 一个人可以尝试读取一个文件,而另一个人正在写入它。

有些系统尝试1来协调这类事情(例如,Dropbox)。 Git 不是其中之一。不要这样做。 (也不要将 Git 存储库放在 Dropbox 区域中。)

基本上,当人们做这种事情时会发生的事情是,它工作了一段时间,然后就坏了,没有人能弄清楚到底发生了什么。2(这是用允许线程或其他并发竞争的语言编写的程序也会发生同样的事情。)


1try这个词在这里是有原因的:这些系统总是有一些极端情况,他们无法确定哪个版本是正确的“最新”版本,并开始做一些事情,比如将 file.ext 变成 file.ext (1)file.ext (2) 并强制用户解决冲突。对关键的 Git 内部文件(例如包含 HEAD ref 的文件)执行此操作将破坏存储库。

2在一些类似的情况下,我得到了很好的报酬来弄清楚发生了什么and/or收拾残局。随着咨询演出的进行,这些都不错。