git worktree与分支依靠隔离

打印 上一主题 下一主题

主题 541|帖子 541|积分 1625

git worktree先容

git worktree 是 Git 命令,用于管理多分支工作区。
使用场景

  • 同时维护不同分支,隔离分支依靠差异:从原有项目开辟一个分支作为另一个新项目,当两个项目依靠差距越来越大时,每次切换分支后都必要重新安装依靠。通过git worktree 可以隔离两个分支的依靠,并且两个分支可以互相merge、cherry-pick。
  • 多个分支同步开发:允许在同一存储库中的不同分支上同时进行工作,而不必要频繁切换分支,这对于必要同时处理多个功能或修复多个 bug 的环境非常有用。
  • 进行实验性更改:在不影响主工作目次的环境下,尝试进行实验性的更改或调试。
  • 同时进行长期和短期使命:有助于同时处理长期开发使命和短期修复使命,而无需相互影响或混淆。
以下是 git worktree 的子命令:

  • add:在当前分支下创建一个新工作区。
  • remove:删除一个已添加的工作区。
  • list:显示所有已添加的工作区。
  • lock:锁定工作区以防止在合并或其他操作时被意外删除。
  • unlock:手动取消工作区的锁定。
git worktree add  [(-b | -B) ]

在当前分支下创建一个新工作区,效果类似于git clone ,但新旧工作区属于同一个仓库,可以正常add、commit、merge等操作。

  • :要创建的新工作区的路径,一样平常建立在当前目次的上一层,如../newpath。
  • :要在哪个分支上创建工作区。假如未指定,则表示基于当前分支HEAD创建新分支。-b表示基于当前分支HEAD创建新分支,-B表示强制创建。
注意:

  • 原始仓库默认是一个工作区,关联当前checkout的分支!
  • 只能创建未被关联的分支,或者通过-b 指令创建新分支!
  • 可以理解为一个工作区一个HEAD,但是不能多个HEAD指向同一个分支。
  1. # 基于HEAD创建工作区../brance1,分支为brance1
  2. # 相当于 git worktree add ../brance1 -b brance1
  3. git worktree add ../brance1
复制代码
  1. # 关联branch2创建工作区../brance1,分支为brance2
  2. git worktree add ../brance1 branch2
复制代码
  1. # 基于HEAD创建工作区../brance1,分支为brance2
  2. git worktree add ../brance1 -b brance2
复制代码
git worktree remove

移除worktree有两种方式。

  • 方式一:
  1. # 移除指定工作区<worktree>
  2. git worktree remove <worktree>
复制代码

  • 方式二:直接删除工作区对应的文件夹,然后执行
  1. # 清除worktree记录
  2. git worktree prune
复制代码
注意:删除工作区,关联的分支并不会被删除哦!
git worktree list

显示所有已添加的工作区。
  1. git worktree list
  2. # 显示完整的hash值
  3. git worktree list --porcelain
复制代码
git worktree lock

用于锁定工作区,以防止在合并或其他操作时被意外删除。
git worktree unlock

解锁工作区。
git worktree处理分支依靠冲突

配景

现在远程仓库有一个项目gitworktree,存在两个分支vue和react,两个分支作为两个项目并行开发,且两分支下的依靠存在差异。
步调

1、 将gitworktree目次下所有内容迁移到新的文件夹gitworktree/project1,方便在一个文件夹下管理。
2、 在目次gitworktree/project1下,执行git worktree add ../vue vue。执行完后可以发现gitworktree目次下存在两个文件夹,分别是project1 和 vue。
3、 在目次gitworktree/project1下,执行git worktree add ../react react。执行完后可以发现gitworktree目次下存在三个文件夹,分别是project1 、 vue 和 react。
这时候就可以舒畅的玩耍了,可以像往常一样add、commit、merge,甚至cherry-pick!两个分支vue 和 react已经隔离开了,且依靠互不影响。
与往常不同的是,vue和react之间不能互相切换分支,只必要打开对应工作区即可进入对应的分支。

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
回复

使用道具 举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

南七星之家

金牌会员
这个人很懒什么都没写!

标签云

快速回复 返回顶部 返回列表