我们是由60多名开发人员组成的团队,他们正在开发相同的产品,并且正在从SVN迁移到Git和GitHub。我们在SVN中有一个进程,在单个文件被锁定的情况下,每当开发人员想要提交代码时,他都需要由文件所有者解锁。我们三个人是150多个文件的拥有者。解锁之前是代码审查。
在Github中,我们计划使用Fork-Clone模型 - 每个项目正在开发的一组dev将执行fork,每个开发人员都会执行fork的克隆,编写代码并提交到origin,the lead of the功能将向上游执行拉取请求。
虽然这看起来很好,但问题是当一个大项目交付时,它会带来大量的更改以供审阅,从而增加了文件所有者的负担。此外,这可能发生在后期的开发周期中,因此项目可能会受到危害。
我们认为可能有用的一种方法是在git push完成原点(fork)时使用钩子。可以有一个最终评论git pull to upstream。
但是,我们找不到任何github扩展或推送挂钩。有没有一个快速的方法(阅读,现有的扩展)与Github这样做或我们应该使用我们将与git使用相同的钩子?
这个用例是Git比SVN好得多的原因之一 - > rebase!如果您遵循良好的git工作流,则在提交Pull请求之前从上游进行重新绑定。你不需要担心文件锁定和踩到另一个人的提交和合并冲突等...一个rebase将你的工作放在一边,应用远程提交,然后在顶部应用你的工作。
我认为这只需要在你的过程中进行重新思考,并依靠git的优势与强制在git之上安装Subversion工作流。您的“fork-clone”模型也可能需要另外一个外观。大多数情况下,每个开发人员都有自己的分支,如果需要,您可以通过团队之间的远程分享回购。但是,共享相同来源的贡献者设置了一些坏习惯。
Gitflow是一个非常受欢迎的git工作流程,和Github themselves has some nice tips and shares their workflow。
没有机会,如果文件不可合并而你需要锁定它,请使用集中式解决方案而不是GIT,即SVN或ClearCase。
如果您使用git LFS
(某些git托管服务提供商支持,如GitHub),您可以使用File Locking。
通过编辑.gitattributes
文件将文件类型标记为可锁定:
*.docx lockable
# Make MS Word files lockable
锁定它:
$ git lfs lock example.docx
您可以通过添加git lfs unlock example.docx
来使用--force
和其他人解锁您的文件。
Git不提供任何锁定功能,因为它是分散的。但是,如果你在GitLab Enterprise Edition Premium上托管你的代码,你可以use the web interface to lock individual files or folders,完全达到你想要做的。
如果您不想在其他人的服务器(他们的网站)上托管您的项目,您也可以下载GitLab并将其托管在您自己的网络服务器上。
不完全锁定,但Github引入了一个名为“Code Owners”的概念。允许您将部分代码库限制为仅在代码所有者审核后允许提交
这个有可能。 git-lfs 2.0引入了锁定文件的能力:请参阅以下链接:https://github.com/git-lfs/git-lfs/wiki/File-Locking。从TFS 2017.2开始支持此功能:https://docs.microsoft.com/en-us/vsts/release-notes/。
在Git中无法做到这一点。正如其他人所说,如果文件是“合法的”,你可以尝试变基,改变你的行为方式。在我们的例子中,我们有一个约定:如果你真的需要锁定它,重命名它。但是我们只在办公室文件等中做这些事情。 这种贡献并没有给出解决方案,这是一种解决方法(但stackoverflow不允许我将其添加为注释。