Git Worktree 是什么?
git worktree 是 Git 自带的多分支并行工作 工具,它能让你在同一个 Git 仓库下,同时检出多个不同分支,并且每个分支都有独立的工作目录(文件夹)。
简单说:不用频繁切换分支、不用克隆多个仓库,就能同时开发/调试多个分支。
一、解决什么痛点?
平时用 Git 切换分支时,会遇到这些麻烦:
- 开发到一半,要紧急改另一个分支的 bug,必须先
commit/stash暂存代码,很繁琐; - 切换分支后,工作目录文件会被覆盖,容易误改、误删;
- 想同时对比两个分支的代码、运行两个版本的项目,只能重复克隆仓库,浪费空间。
git worktree 完美解决这些问题。
二、核心特点
- 共享同一个 .git 仓库:所有工作目录共用仓库的提交历史,不重复占用磁盘空间;
- 独立工作目录:每个分支一个文件夹,互不干扰;
- 无需频繁切换分支:直接打开对应文件夹就能开发;
- 原生 Git 命令:不用装插件,Git 2.5+ 版本自带。
三、常用命令(直接复制用)
1. 查看当前所有工作树
bash
git worktree list
会显示:主目录 + 所有附加的工作树、对应分支、路径。
2. 创建新的工作树(指定分支)
bash
# 格式:git worktree add <文件夹名> <分支名>
git worktree add bug-fix fix-branch-123
执行后:
- 会生成
bug-fix/文件夹; - 自动检出
fix-branch-123分支; - 直接进入这个文件夹就能开发,和主目录完全隔离。
3. 删除不需要的工作树
bash
# 先删除文件夹,再清理 Git 记录
rm -rf bug-fix
git worktree prune
4. 快速创建新分支 + 新工作树
bash
git worktree add new-feature -b new-branch-name
四、使用场景(最实用)
- 紧急修复 bug :主分支开发到一半,直接开一个 worktree 切到修复分支,改完提交,回到主分支继续写代码,不用 stash、不用切换;
- 同时开发多个功能:一个目录写功能 A,一个目录写功能 B,互不干扰;
- 对比/测试两个版本:同时运行生产分支、开发分支,方便调试差异;
- ** reviewing 代码**:给同事的分支建一个独立目录,直接查看、运行代码。
五、和普通切换分支、多克隆仓库的区别
| 方式 | 优点 | 缺点 |
|---|---|---|
| git checkout 切换分支 | 简单,适合临时切换 | 干扰当前工作,容易出错 |
| 克隆多个仓库 | 完全隔离 | 占用双倍空间,同步提交麻烦 |
| git worktree | 隔离、共享仓库、不占空间、高效 | 需记住命令(很简单) |
总结
git worktree= 同一个 Git 仓库,多个独立分支工作目录;- 核心价值:不切换分支、不重复克隆,同时并行处理多个分支;
- 高频命令:
add(创建)、list(查看)、prune(清理)。