如何解决在同一个存储库上运行的多个 git 实例是否会产生问题?
我的雇主刚刚转用git,所以我的同事还有些缺乏经验。他们现在的所作所为让我很担心,所以我正在写这篇文章。
他们在一台机器上克隆了一个 git 存储库,然后通过 windows 共享共享该存储库。 现在,在共享存储库的机器上,他们正在处理它。 只要不超过一个人同时工作,这种方法的效果出奇地好。
还没有爆炸,但我对此有一种不好的预感。
会出什么问题?或者这样做真的安全吗?
在有人问之前: 他们这样做是因为该共享目录上有他们不想复制到他们机器上的脚本。我试着说服他们不要这样做,但他们非常喜欢这个想法。
解决方法
如果他们所有人只阅读这个共享区域,那就没问题了。 (当有人更新共享区域时,他们都必须停止阅读。)
写入共享区域通常是个坏主意,因为:
- 两个人可以尝试写入同一个文件;
- 一个人可能会尝试读取文件,而其他人则在写入文件。
有些系统尝试1来协调这类事情(例如,Dropbox)。 Git 不是其中之一。不要这样做。 (也不要将 Git 存储库放在 Dropbox 区域。)
基本上,当人们做这种事情时会发生什么,它工作了一段时间,然后它就坏了,没有人能准确地弄清楚发生了什么。2(这和发生的事情是一样的使用允许线程或其他并发竞争的语言编写的程序。)
1出现try这个词是有原因的:这些系统总是有一些极端情况,它们无法确定哪个版本是正确的“最新”版本,并且开始做一些事情,比如将 file.ext
变成 file.ext (1)
和 file.ext (2)
并强制用户解决冲突。对关键的 Git 内部文件(例如保存 HEAD
引用的文件)执行此操作会破坏存储库。
2在一些类似的情况下,我得到了高薪来弄清楚发生了什么和/或清理混乱。就咨询工作而言,这些都不错。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。