使用 Git bisect 命令定位首次引入错误的提交
你是不是有过这样的经历:发现代码中有 错误bug,但不知道这个错误是什么时候引入的。这有可能是因为,某个人提交了一份有错误的代码,但没有在他的 Git 提交commit 消息中声明它。这个错误可能已经存在了几周、几个月甚至几年,这意味着你需要搜索数百或数千个提交,才能找到问题何时出现的。而 git bisect
命令能够完美地解决这个问题!
git bisect
命令是一个强大的工具。你可以给 git bisect
命令一个范围,一端是一个已知的好状态,另一端是一个已知的坏状态。它会自动地确认当前范围的中点,在这个中点上进行测试,然后要求你确定那次提交是一个 好提交good commit 还是一个 坏提交bad commit,然后它会重复这一“二分查找”的过程,直到你找到首次引入错误的那一次提交。
Image of Zeno's paradox of Achilles.
这个“数学”工具是利用“二分查找”来找到错误之处的。git bisect
命令通过查看中点,然后由你来决定它是提交列表的新起点(即 “坏提交” )还是新终点(即 “好提交”),进而来缩小查找范围,如此在几次查找中你可以就能定位到有错误的提交。即使你有 10,000 个提交要检查,最多只需要 13 次查找,就能很快地定位到首次引入错误的提交。
- 提交 1 坏 <> 提交 10,000 好 => 提交 5,000 是坏的
- 提交 5,000 坏 <> 提交 10,000 好 => 提交 7,500 是好的
- 提交 5,000 坏 <> 提交 7,500 好 => 提交 6,250 是好的
- 提交 5,000 坏 <> 提交 6,250 好 => 提交 5,625 是坏的
- 提交 5,625 坏 <> 提交 6,250 好 => 提交 5,938 是坏的
- 提交 5,938 坏 <> 提交 6,250 好 => 提交 6,094 是好的
- 提交 5,938 坏 <> 提交 6,094 好 => 提交 6,016 是坏的
- 提交 6,016 坏 <> 提交 6,094 好 => 提交 6,055 是好的
- 提交 6,016 坏 <> 提交 6,055 好 => 提交 6,036 是坏的
- 提交 6,036 坏 <> 提交 6,055 好 => 提交 6,046 是坏的
- 提交 6,046 坏 <> 提交 6,055 好 => 提交 6,050 是坏的
- 提交 6,050 坏 <> 提交 6,055 好 => 提交 6,053 是好的
- 提交 6,053 坏 <> 提交 6,055 好 => 提交 6,054 是好的
对于上面这个例子,我们能知道 10,000 个提交中的第一个错误提交是第 6053 次提交。对于 git bisect
命令,最多需要几分钟就能完成检索。但是如果要一个一个查找每个提交是否错误,我甚至无法想象需要多长时间。
使用 Git bisect 命令
git bisect
命令使用起来非常简单:
(LCTT 译注:使用 git bisect start
命令来进入 bisect 模式,并且该命令指定了一个检查范围。它会告诉我们一共有多少次提交,大概需要几步就可以定位到具体的提交。)
Git 检查中间的提交,并等待你声明这次提交是一个好提交还是一个坏提交:
(LCTT 译注:如果某一提交是可以通过的,则使用 git bisect good
命令标记;同样地,如果某一提交不能通过,则使用 git bisect bad
命令标记。)
或
然后,git bisect
工具重复检查好提交和坏提交中间的那次提交,直到你告诉它:
一些高级用户甚至可以自己编写脚本,来确定提交的好坏状态、并在找到特定提交时采取某一补救措施。你可能不会每天都使用 git bisect
命令,但当你需要它来定位首次引入错误的提交时,它会是一个很有用的救星。
相关文章
- Jgit的使用笔记
- 利用Github Action实现Tornadofx/JavaFx打包
- 叹息!GitHub Trending 即将成为历史!
- 微软软了?开源社区讨论炸锅,GitHub CEO 亲自来答
- GitHub Trending 列表频现重复项,前后端都没去重?
- Photoshop Elements 2021版本软件安装教程(mac+windows全版本都有)
- (ps全版本)Photoshop 2020的安装与破解教程(mac+windows全版本都有)
- (ps全版本)Photoshop cc2018的安装与破解教程(mac+windows全版本,包括2023
- 环境搭建:Oracle GoldenGate 大数据迁移到 Redshift/Flat file/Flume/Kafka测试流程
- 每个开发人员都要掌握的:最小 Linux 基础课
- 来撸羊毛了!Windows 环境下 Hexo 博客搭建,并部署到 GitHub Pages
- 超实用!手把手入门 MongoDB:这些坑点请一定远离
- 【GitHub日报】22-10-09 zustand、neovim、webtorrent、express 等4款App今日上新
- 【GitHub日报】22-10-10 brew、minio、vite、seaweedfs、dbeaver 等8款App今日上新
- 【GitHub日报】22-10-11 cobra、grafana、vue、ToolJet、redwood 等13款App今日上新
- Photoshop 2018 下载及安装教程(mac+windows全版本都有,包括最新的2023)
- Photoshop 2017 下载及安装教程(mac+windows全版本都有,包括最新的2023)
- Photoshop 2020 下载及安装教程(mac+windows全版本都有,包括最新的2023)
- Photoshop 2023 资源免费下载(mac+windows全版本都有,包括最新的2023)
- 最新版本Photoshop CC2018软件安装教程(mac+windows全版本都有,包括2023