git worktree与分支依赖隔离的使用场景分析

 更新时间:2024年04月12日 09:14:34   作者:前端cry  
git worktree 是 Git 命令,用于管理多分支工作区,这篇文章主要介绍了git worktree与分支依赖隔离,需要的朋友可以参考下

git worktree介绍

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

使用场景

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

以下是 git worktree 的子命令:

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

git worktree add <path> [(-b | -B) <new-branch>]

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

  • <path>:要创建的新工作区的路径,一般建立在当前目录的上一层,如../newpath
  • <new-branch>:要在哪个分支上创建工作区。如果未指定<new-branch>,则表示基于当前分支HEAD创建新分支<path>-b表示基于当前分支HEAD创建新分支<new-branch>-B表示强制创建。

注意:

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

git worktree remove <worktree>

移除worktree有两种方式。

  • 方式一:
# 移除指定工作区<worktree>
git worktree remove <worktree>
  • 方式二:直接删除工作区对应的文件夹,然后执行
# 清除worktree记录
git worktree prune

注意:删除工作区,关联的分支并不会被删除哦!

git worktree list

显示所有已添加的工作区。

git worktree list
# 显示完整的hash值
git worktree list --porcelain

git worktree lock <worktree>

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

git worktree unlock <worktree>

解锁工作区<worktree>

git worktree处理分支依赖冲突

背景

现在远程仓库有一个项目gitworktree,存在两个分支vuereact,两个分支作为两个项目并行开发,且两分支下的依赖存在差异。

步骤

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已经隔离开了,且依赖互不影响。

与往常不同的是,vuereact之间不能互相切换分支,只需要打开对应工作区即可进入对应的分支。

到此这篇关于git worktree与分支依赖隔离的文章就介绍到这了,更多相关git worktree与分支依赖隔离内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Postman传递对象参数(包含有集合对象)

    Postman传递对象参数(包含有集合对象)

    postman通常需要传递各式各样的参数,本文主要介绍了Postman传递对象参数(包含有集合对象),具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-01-01
  • 解决IDEA中编辑HTML格式文件不自动缩进问题

    解决IDEA中编辑HTML格式文件不自动缩进问题

    这篇文章主要介绍了解决IDEA中编辑HTML格式文件不自动缩进问题,本文内容简短,解决方法给大家提出了,需要的朋友可以参考下
    2020-01-01
  • git如何撤销commit的方法(未push)

    git如何撤销commit的方法(未push)

    这篇文章主要介绍了git如何撤销commit的方法(未push),文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-07-07
  • 如何设计一个几十万在线用户弹幕系统需求方案

    如何设计一个几十万在线用户弹幕系统需求方案

    这篇文章主要介绍了为大家如何设计一个几十万在线用户弹幕系统的需求实现方案详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪<BR>
    2023-05-05
  • Visual Studio 2022 集成 GIT 使用图文教程

    Visual Studio 2022 集成 GIT 使用图文教程

    本文详细介绍了VisualStudio2022与GIT集成的操作步骤,包括下载GIT、安装和配置GIT、以及如何在VisualStudio2022中下载GIT项目和上传项目到GIT服务器,感兴趣的朋友跟随小编一起看看吧
    2024-09-09
  • vscode远端配置及一些问题解决方案

    vscode远端配置及一些问题解决方案

    我们之前大概了解了vscode的本地设置,我们之前提过,vscode是一款编辑器,在文本编辑方面有着强大的功能,vscode强大的功能还在于可以连接远端机器,为我们的远端机器服务,今天我们主要来进行远端配置,感兴趣的朋友跟随小编一起看看吧
    2024-03-03
  • wkhtmltopdf 最好用Html转pdf的工具

    wkhtmltopdf 最好用Html转pdf的工具

    这篇文章主要介绍了wkhtmltopdf 最好用Html转pdf的工具,需要的朋友可以参考下
    2017-09-09
  • adb shell input keyevent 控制按键输入的数值(收藏版)

    adb shell input keyevent 控制按键输入的数值(收藏版)

    adb shell的功能很强大,可以使用很多功能,今天我们说下通过控制按键输入,需要的朋友可以参考下
    2019-10-10
  • Eclipse 格式化代码时不换行与自动换行的实现方法

    Eclipse 格式化代码时不换行与自动换行的实现方法

    每次用Eclipse自带的Ctrl+shift+f格式化代码时,如果原来的一行代码大于80列,Eclipse就会自动换为多行,这点个人感觉不是很舒服,简单试了一下,通过以下方式可以修改
    2009-05-05
  • VS2019创建MFC程序的实现方法

    VS2019创建MFC程序的实现方法

    这篇文章主要介绍了VS2019创建MFC程序的实现方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-08-08

最新评论