Redian新闻
>
使用 Git bisect 命令定位首次引入错误的提交 | Linux 中国

使用 Git bisect 命令定位首次引入错误的提交 | Linux 中国

科技
 
导读:Git 的 bisect 工具通过快速识别坏的提交,节省了时间和精力。                   
本文字数:2341,阅读时长大约:3分钟

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. 提交 1 坏 <> 提交 10,000 好 => 提交 5,000 是坏的
2. 提交 5,000 坏 <> 提交 10,000 好 => 提交 7,500 是好的
3. 提交 5,000 坏 <> 提交 7,500 好 => 提交 6,250 是好的
4. 提交 5,000 坏 <> 提交 6,250 好 => 提交 5,625 是坏的
5. 提交 5,625 坏 <> 提交 6,250 好 => 提交 5,938 是坏的
6. 提交 5,938 坏 <> 提交 6,250 好 => 提交 6,094 是好的
7. 提交 5,938 坏 <> 提交 6,094 好 => 提交 6,016 是坏的
8. 提交 6,016 坏 <> 提交 6,094 好 => 提交 6,055 是好的
9. 提交 6,016 坏 <> 提交 6,055 好 => 提交 6,036 是坏的
10. 提交 6,036 坏 <> 提交 6,055 好 => 提交 6,046 是坏的
11. 提交 6,046 坏 <> 提交 6,055 好 => 提交 6,050 是坏的
12. 提交 6,050 坏 <> 提交 6,055 好 => 提交 6,053 是好的
13. 提交 6,053 坏 <> 提交 6,055 好 => 提交 6,054 是好的

对于上面这个例子,我们能知道 10,000 个提交中的第一个错误提交是第 6053 次提交。对于 git bisect 命令,最多需要几分钟就能完成检索。但是如果要一个一个查找每个提交是否错误,我甚至无法想象需要多长时间。

使用 Git bisect 命令

git bisect 命令使用起来非常简单:

(LCTT 译注:使用 git bisect start 命令来进入 bisect 模式,并且该命令指定了一个检查范围。它会告诉我们一共有多少次提交,大概需要几步就可以定位到具体的提交。)

  1. $ git bisect start
  2. $ git bisect bad # Git assumes you mean HEAD by default
  3. $ git bisect good <ref> # specify a tag or commit ID for <ref>

Git 检查中间的提交,并等待你声明这次提交是一个好提交还是一个坏提交:

(LCTT 译注:如果某一提交是可以通过的,则使用 git bisect good 命令标记;同样地,如果某一提交不能通过,则使用 git bisect bad 命令标记。)

  1. $ git bisect good

  1. $ git bisect bad

然后,git bisect 工具重复检查好提交和坏提交中间的那次提交,直到你告诉它:

  1. $ git bisect reset

一些高级用户甚至可以自己编写脚本,来确定提交的好坏状态、并在找到特定提交时采取某一补救措施。你可能不会每天都使用 git bisect 命令,但当你需要它来定位首次引入错误的提交时,它会是一个很有用的救星。


via: https://opensource.com/article/22/11/git-bisect

作者:Dwayne McDaniel 选题:lkxed 译者:chai001125 校对:wxy

本文由 LCTT 原创编译,Linux中国 荣誉推出

LCTT 译者 :chai001125
🌟🌟🌟
翻译: 20.0 篇
|
贡献: 55 天
2022-10-06
2022-11-30
https://linux.cn/lctt/chai001125
欢迎遵照 CC-BY-SA 协议规定转载,
如需转载,请在文章下留言 “转载:公众号名称”,
我们将为您添加白名单,授权“转载文章时可以修改”。

微信扫码关注该文公众号作者

戳这里提交新闻线索和高质量文章给我们。
相关阅读
Acciona Energía 收购德州最大的电池储能项目Arch Linux 中用于包管理的图形化应用 | Linux 中国在 Linux 中创建 LVM 分区的分步指南 | Linux 中国“电热毯”用electric 还是 electrical?如何在 Linux 中使用 SCP 安全地传输文件 | Linux 中国准备好在 Debian Linux 上获得 Ubuntu MATE 的体验吧! | Linux 中国使用 PCManFM 文件管理器让你的 Linux PC 轻装上阵 | Linux 中国一路向北:开篇以及奥勒松 ——2022北极旅行纪实之一Rosalía 登意大利版《VOGUE》封面!一个适用于苹果芯片的原生 Linux GPU 驱动程序几乎就绪! | Linux 中国投融资周报:市值近276亿元,北京最老牌晶圆厂燕东微科创板上市;鞍钢矿业首次引入战略投资67.1亿元丨12.10-12.16China Vows to Strengthen Intellectual Rights Protection使用这个多功能的 Linux 命令转换音频文件 | Linux 中国八大山人醉酒画松在 Linux 中如何从命令行查找默认网关的 IP 地址 | Linux 中国System 76 将不会发布 Pop!_OS 22.10 Linux 发行版 | Linux 中国Tuxedo 已对所有用户开放基于 Ubuntu 的 TUXEDO OS | Linux 中国恼人的提问和好奇的提问Linux 中的 su 和 sudo 命令有什么区别? | Linux 中国解决 Linux 中的 “Bash: Command Not Found” 报错 | Linux 中国如何在最小安装的 CentOS、RHEL、Rocky Linux 中设置互联网 | Linux 中国如何在 sudo 运行的命令中防止使用参数 | Linux 中国设置路径在 Powershell 中使用开源命令 | Linux 中国用 git log 命令显示在特定日期的提交记录 | Linux 中国在美国244.为何突然怪事多多?使用 PSCP 将文件和文件夹从 Windows 传输到 Linux | Linux 中国在 Linux 中使用 “Converter” GUI 工具转换和操作图像 | Linux 中国首次引入!用因果推理做部分可观测强化学习|AAAI 2023难得一见的历史老照片15张通过 SSH 在远程 Linux 系统上执行命令 | Linux 中国12 个对新手最重要的 Linux 命令 | Linux 中国如何在 Arch Linux 中启用 Snap 支持 | Linux 中国开源朗读者:使用 Linux 的优势和劣势 | Linux 中国又收到一张支票LURE 初窥!将 AUR 带入所有 Linux 发行版 | Linux 中国
logo
联系我们隐私协议©2024 redian.news
Redian新闻
Redian.news刊载任何文章,不代表同意其说法或描述,仅为提供更多信息,也不构成任何建议。文章信息的合法性及真实性由其作者负责,与Redian.news及其运营公司无关。欢迎投稿,如发现稿件侵权,或作者不愿在本网发表文章,请版权拥有者通知本网处理。