Git屠龙技:使用Git Worktree并行开发测试

在开发工作中,大家估计都遇到过这样的需求:正在开发的东西不想动,但是需要一个完整工作目录来做测试或者搞一些其他事情。一般来说可以拉个分支,用git stash保存目前的工作区状态,等搞完事情再切回来。但是如果需要两个或者更多个工作区同时搞事情上面的方案就不行。这时候当然可以git clone几个完整仓库副本来搞,但是也很麻烦费事,而且仓库的同步也是个问题。有没有更好的方法呢?在次之前我是不知道的,知道我发现了git的一个新的屠龙技——git worktrees工作树功能。今天虫虫就给大家介绍这个新的鲜为人知的万人需屠龙秘籍。

概述

Git worktree严格意义上说已经不是一个新的功能了,它推出也已经好几年了,是在2015年7月发布的2.5版引入的。Worktree是链接到统一仓库的多个工作区(目录,树)。一个git仓库可以支持多个工作树,分别对应不同的分支。我们在git中通过"git init"或"git clone"创建一个(主)工作区(树)(main working tree)。

同理,我们使用git worktree创建一个(和工作区)不同目录的工作区(树),我们称之为为"链接工作区(树)(linked working tree)"。git仓库有一个主工作树(裸库)和零个或多个链接工作树。与重建的孤立的目录不同,链接工作树和主仓库直接就行分支一样是有机关联的,任何一个链接工作树的变更提交都在仓库内部。链接工作树用完后,可以直接通过git worktree remove删除。

工作区和工作树

基本用法

基本用法

add

工作树的创建和创建新分支一样简单而高效。运行下面的格式创建工作树:

git worktree add ../工作树目录 分支(commits ID)

该命令就会在../工作树目录下,创建一套完整分支工作区。该目录可以任意指定,但是最好在主仓库目录之外,免得污染仓库。然后就可以在该目录下检出分支,向上游推送,等等。

如果分支不存在,则可以用-b操作,可以新建分支并使这个新分支关联到工作树。

list

list功能会列出每个工作树的详细信息。首先列出主工作树,然后列出每个链接工作树。输出详细信息包括工作树是否为裸树,工作树对应git commit哈希以及对应的分支(如果没有,则为分离的HEAD)。

git worktree list

list功能有一个--porcelain 选项,可以列出更完整的哈希值和分支信息

--porcelain选项

lock

如果工作树目录位于便携式设备或网络共享上,请使用lock对其进行锁定,以防止其管理文件被自动删除。这也可以防止其被移动或删除。

move

将工作树移动到新目录。请注意,不能移动包含子模块的主工作树或链接的工作树。比如我们执行:

git worktree move alpha ../a

对未操作以前变化:

git worktree move

prune

清楚$GIT_DIR/worktrees中的工作树信息。

remove

前面提到过,用户删除工作树。注意:该命令只能删除干净的工作树(没有未跟踪的文件,也无法对跟踪的文件进行任何修改)。不干净的工作树或带有子模块的树需要使用--force删除。主工作树无法删除。

unlock

对锁定工作中的树,解锁,解锁后就可以对其进行prune、move或者remove等操作。

工作树的作用

那么用工作树可以搞什么事情呢?这儿就介绍介绍工作树的作用。

在另一个分支上工作时运行测试

在具有非常好的测试覆盖范围的大型项目中,运行某组测试套件可能需要很长时间,与其浪费时间死等,不如多拉几个工作树并行运行多个测试套件。许多IDE都允许一次打开多个项目,但每个项目必须位于自己的目录中。我们可以git克隆两个完全独立的存储库,但是工作树更完美:

工作树是使用硬链接实现的,因此它们既轻巧又快速。

可以在工作树之间共享更改(只要它们将其提交到本地存储库)。对于克隆,必须先推送到远程库,在git pull来同步。

如果不小心clone的副本提交错误的提交了变化,则必须手工(如果很简单)或使用修补程序迁移变更。而使用工作树,只需要使用git cherry-pick和git reset即可修复错误。

通常做法是为运行测试保留一个额外的工作树。但是工作树有一个限制就是一个分支只能拉一个工作树。可以通过创建临时分支来解决这个问题,如下所示:

git checkout -b TEMP/branch feature/branch

此处使用TEMP前缀来强调该分支是临时的。当在原始分支上提交更改时,可以方便的使用git merge feature/branch同步分支。

比较多个版本

有时,需要比较一个项目的某两个版本,但仅用diff无法做得到。可能需要同拉两个版本逐个比对,甚至需要同时运行本。或者一个复杂的功能恰好写了一半,无法确定从那个地方做标记对比,这时可以通过先前的版本或者任何commit提交来拉工作树操作。

在其他分支上工作,而不会影响当前的工作副本

也许我们需要在其他分支上工作,但是当前的工作目录混乱不堪,也无法使用git stash来保存状态。根据项目的不同,切换分支有可能还会产生不良的副作用(例如,导致IDE重新生成索引)。这时候就只能使用工作树来解决。

使用工作树快速验证项目

每个人都可能遇到过构建失败的经历,可能是因为你搭档忘记提交一些必须的配置或.gitgnore设置的太宽泛了等等。而代码可以很好的在它的电脑上运行,到你这就挂了,则可能是由于可能缺少某些文件。这时候就可以使用工作树拉一个干净的副本做测试验证所有需要包含都已经添加了。只有从创建新工作树开始,才能可靠地工作。

限制

不能多个工作树对应同一个分支

前面提到了过了,这是工作树的一个限制,只需拉一个临时分支就ok。

不适用于子模块

目前使用子模块的存储库无法利用工作树。

总结

本文给大家介绍了一个非常实用的git功能——工作树。该功能简练而好用,绝对是一个人见人爱,人见人用的五星级好功能。犹豫什么呢,先用先受益!

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,271评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,275评论 2 380
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,151评论 0 336
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,550评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,553评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,559评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,924评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,580评论 0 257
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,826评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,578评论 2 320
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,661评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,363评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,940评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,926评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,156评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,872评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,391评论 2 342

推荐阅读更多精彩内容

  • 简介 Git是一个开源的分布式版本控制系统,用于敏捷高效地处理任何或小或大的项目。 Git 与常用的版本控制工具 ...
    闽越布衣阅读 2,732评论 0 18
  • Git 是目前最流行的分布式版本控制系统之一。 版本控制指的是,记录每次版本变更的内容和时间等细节,保留各版本之间...
    神齐阅读 1,396评论 0 7
  • 前言 Git使用教程 Git是什么 Git是一个开源的分布式版本控制系统,用于敏捷高效地处理任何或小或大的项目。 ...
    90后的思维阅读 894评论 0 0
  • 1、 小时候,爷爷拄着拐站在村口,村口有条路,通往山的尽头。 山的尽头是海,海边是座小城,城里有抽着烟的父亲,有我...
    游民王阿牛阅读 2,600评论 21 56
  • 【第一世】 我是人。 七岁,爸爸捉了只老鼠,当时我看着老鼠有股莫名的兴奋。爸爸把老鼠拿根绳子栓起来,把绳头递给我说...
    西瓜椰椰阅读 666评论 3 12