Git 二分调试法,火速定位疑难Bug!

你一定遇到过,一个很久没修改过的功能,莫名其妙的出现了问题?肉眼查代码、屡逻辑完全找不到问题点?前两天还好好的功能,怎么这个今天就不行了?这两天改动了这么多代码,到底是那一次改动引发的 Bug?

这样非崩溃的 Bug,有时候想要排查出问题,并不是一件容易的事情。我想,这个时候你会需要 git bisect !

一、git bisect 基础使用

git bisect 是 Git 提供的一种 二分法 的调试工具,它可以按照我们选定的提交,进行二分分割,快速定位出出错的提交。来帮我们缩小最小改动的代码,从而快速定位问题。

git bisect 其实很简单,主要是基于几个基本命令:

  • git bisect start:准备进行 bisect debug。
  • git bisect good:标记一个提交为 "good"。
  • git bisect bad:标记一个提交为 “bad”。
  • git bisect reset:退出 bisect debug 的状态。

git bisect 涉及到的命令,非常的清晰简单,下面举个实际的例子,结合上面的解释,就更清晰了。

二、git bisect 工作流

我自己生造出 6 个 commit,然后使用 git log 看看我的提交记录。

gitlog

这里假设我正常开发的阶段,到 v6 提交的时候,突然发现有个 Bug ,无法定位到问题,但是能明确的知道,在 v1 提交阶段,并没有这个 Bug。

那么,在这样的情况下,v6 就是一个有问题的版本,而 v1 则是一个好的版本,我们就可以借助 git bisect 来进行二分超找定位问题来自哪个提交。

还记得刚才的命令吗?

我们先用 git bisect start 标记开始 bisect debug ,然后使用 git bisect goodgit bisect bad 分别标记出正确的和错误的提交。

biscet-start

每个提交,都有一个针对这个提交唯一的 SHA-1 值,因为太长不方便输入和阅读,这里可以直接使用前几位作为简写。

当标记处正确的和错误的提交之后,git bisect 立刻就可以帮我们定位出中间提交 v3

现在 HEAD 就已经指向了 v3 提交的代码了,这个可以使用 git status 查看当前的状态。

git-status

所以我们可以基于 v3 版本的代码,直接运行项目,测试看该提交是否有问题。

经过测试之后,发现 v3 的提交代码版本,并没有复现 Bug,那我们就可以缩小错误提交的范围,大概落在了 v4v5v6 之间。

此时,我们只需要使用 git good 标记 v3 版本是正确的。

bisect-good-v3

标记好 v3good 之后,立刻又会进行一次二分,此次标记的为中间提交 v5

经过对 v5 提交的版本代码,进行测试之后发现,它是有问题的。我们继续使用 git bisect bad 对它进行标记。

bisect-bad-v4

v5 有问题的时候,现在只中间一个 v4 版本,所以会立刻指向 v4 提交。

我们继续对 v4 版本的代码进行测试,发现 v4 版本也有问题,继续标记它为 bad

bisect-bad

此时就很明确了,出错的提交就是 v4,而 Git 也直接帮我们指出来出错的提交。

虽然这里定位到,出错的提交就是 v4 的问题,我们只需要仔细阅读 v4 提交的代码,然后定位出问题代码,就达到了我们的目的。但是我们并不应该在 v4 提交上直接修改 Bug,我们应该退出 bisect debug 状态,在最新的提交版本上进行修改,这里使用 git bisect reset 退出,再进行修改即可。

到这里,就是 git bisect 的完整工作流程。

三、bisect的后悔药

对提交进行 goodbad 的标记,都是人为来进行的,难免有出错的情况。而提交比较少的时候,大不了就是 reset 之后,重头来过。

但是如果有几十个提交,再从头进行一次 bisect 就比较麻烦了。Git 考虑到这一点,已经为我们配好了后悔药。

想要擦除之前的标记状态,就涉及到一个命令:

  • git bisect replay:重置到某个状态。

replay 需要制定一个回退的点,这个点是需要使用 git bisect log > log.txt 输出的 Log 文件, 我们需要通过修改这个 Log 文件,来确定回退的点。

举个例子,我们使用 log 命令,输出一个 log.txt 文件。

log

可以看到,这个 log.txt 文件,记录了我们刚才所有的操作。

在这个例子中,假如我们的操作,对 v5 进行 bad 的这个标记错了,那么,我们把这个操作之下的 Log 全部删除掉,然后执行 git bisect replay log.txt

replay

这样就将回退到判断 v5 提交好坏的地方,重新进行标记。

在修改 Log.txt 文件的时候,最好只执行删除操作,不要对其中的顺序有所修改,毕竟我们只是想要一个回滚的动作,并不是要改动我们之前的某些操作。

今天在承香墨影公众号的后台,回复『成长』。我会送你一些我整理的学习资料,包含:Android反编译、算法、设计模式、虚拟机、Linux、Kotlin、Python、爬虫、Web项目源码。

推荐阅读:

[图片上传失败...(image-7375e7-1513741468483)]

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