2018-01-19 01:20
我在 feature
分支开发得多些,但总时不时被高优先级的 BUG 打断需要临时去 develop
分一个分支出来解 BUG。git 2.6 以上开始提供了 worktree 功能,可以解决这样的问题。
阅读本文将了解使用 git worktree 高效进行并行开发的方法。
git worktree 从一个仓库中可以创建多个工作目录,方便多开编辑器并行开发。
git worktree add -b <新分支名> <新路径> <从此分支创建>
例如,你正在某个 feature
分支开发,希望从 master 分出一个分支来解决某个紧急的 BUG:
git worktree add -b t/walterlv/bugfix-100 ../Demo.bugfix master
这样,原本的仓库文件夹的同级目录下会出现一个 Demo.bugfix 文件夹(当然名字随便取)。这个仓库里只有一个 .git 文件用来记录这是主仓库的一个工作目录。
自此,这两个工作目录在工作上看起来就像两个独立的仓库一样,都可以运行各种命令,包括切换分支。
相比于克隆多个仓库,使用这种方法创建的多个目录,有诸多好处:
使用 git worktree 创建的多个目录,不能有任何两个目录在同一个分支下——原因应该不言自明。
如果要删除其中一个工作目录,直接删除文件夹即可。随后使用命令清除多余的已经被删的工作目录:
git worktree prune
本文会经常更新,请阅读原文: https://walterlv.com/post/git-worktree.html ,以避免陈旧错误知识的误导,同时有更好的阅读体验。
本作品采用 知识共享署名-非商业性使用-相同方式共享 4.0 国际许可协议 进行许可。欢迎转载、使用、重新发布,但务必保留文章署名 吕毅 (包含链接: https://walterlv.com ),不得用于商业目的,基于本文修改后的作品务必以相同的许可发布。如有任何疑问,请 与我联系 (walter.lv@qq.com) 。