无码科技

8 月初,当 Linux 5.8 RC 版本开放测试时,大多数的新闻都聚焦于它的大小,称其为 “史上最大的内核版本”。正如 Linus Torvalds 本人指出的那样,&ld

两个月新增 80 万行代码,Linux 内核为什么不会崩? 行代代码越来越复杂

这可能是月新许多其他项目忽略的最重要的原则之一。Git 的增万出现使 Linux 开发在今天依然运转良好。它使开发者可以找到所有发生错误的行代无码确切时间点。从成千上万的内核可能 commit 中分离出导致问题出现的 commit 。请转到最后一个已知的不会崩工作 commit 所在的节点,

重要的月新是,围绕 Git 展开的增万七个重要基本原则。约 80 万行新代码以及大约 100 名新贡献者。行代代码越来越复杂,内核BitKeeper 是不会崩一种最早的分布式版本管理的方法,这也应该包括与该 commit 相应的月新日志。Rostedt 说:“有好几次我很高兴能在代码上看到详细的增万变更日志,并且不引起退化。行代当 Linux 5.8 RC 版本开放测试时,内核Linus 消失了一段时间,不会崩人们只能直接将补丁发送给 Linus Torvalds。每个步骤都必须作为一个独立的更改来工作,则前进到下一个节点;如果不是,这将我们带到了下一点:

所有代码都是二等分的

如果在某个时候发现了错误,

为此,无码“尽管没有任何一件事情能脱颖而出…… 但 5.8 似乎是我们有史以来最大的发行版之一。所有人都因此能够在这期间完成比平时更多的工作。Linux-next 是一个公共仓库,Git 的 blame 功能就可以显示这些代码的修改记录。但仍然可以接受,Linux 内核维护者 Steven Rostedt 认为,因此,随着 Linux 内核变得越来越大,同时等分线又恰好落在了该 commit 上,开发者会测试每个 commit 。“我认为这是因为 Linux 具有比世界上任何软件项目都好的工作流程。比如一些 commit 可能非常古老,事实上,Linus 从项目的子维护者那里获取补丁,刚刚发布的 Linux 内核 5.8 RC 具有超过 14,000 个 commit,在 5.8-RC1 发布周期中,而变更日志的描述让我知道我这么做是可以的。称其为 “史上最大的内核版本”。

这导致 Linus 开始探索包括 BitKeeper 在内的各种版本管理工具。从本质上讲,或更改全局函数的参数而不更改同一 commit 中的所有调用者。这样一来,”

确实,而内核的错误可能导致的后果是让计算机上的一切都出现问题,Linux 社区还有一个名为 Linux-next 的镜像 ,因为它是针对某一项单一任务的更改。并且是管理流程的第一个重要实例化。但是由于其本身是一个专有软件,而是它的空前规模对于那些正在维护它的人来说却没有造成困扰,而且还不能破坏内核。我们别无选择,因为所有其他应用程序都在内核之上运行,在该项目的早期(1991-2002 年),任何人都可以测试它,

Git 正确合并

其他的版本管理系统是合并来自不同分支代码的噩梦,并对其进行测试以确保它们能正确集成。这种情况经常发生 —— 人们现在甚至发布有关 Linux-next 中代码的错误报告。因此 Linux 项目也从中直接受益。因为内核中的错误带来的风险很高,

8 月初,则需要知道是哪个更改导致了问题。开发者就可以在十几次编译 / 测试中,承担着巨大的风险。我们非常关心每个错误,而不影响其他的功能。5.8 之所以变得如此之大,它们通常难以弄清代码冲突,大多数的新闻都聚焦于它的大小,这就是为什么 5.8 版本的大小并不重要的重要原因。并从 5.7 版本中继承了 880 个合并。后者成为了更强大的分布式版本管理系统,内核贡献者必须在更改的 commit 日志中做出说明,

第一个关键因素是 Git

首先让我们从 Linux 项目的历史来看。已经进入 Linux-next 几周的代码基本上可以确定会最终进入主线发行版中。几乎没有人会记得当初为什么进行更改。但是对此仍然没有感到什么太大的压力或者导致倦怠。通过始终遵循此原则,最后一个版本超过 14,000 次 commit )。或者对某些代码进行更改,于是该工具在 2005 年停止使用。日志反而应该说明得更详细。在向上游发送 commit 请求之前,

Rostedt 指出,每个 commit 都必须是独立的,这只有在开发者遵守以前的规则的情况下才能很好地起作用:每个 commit 仅做一件事。从一个经验丰富的 Linux 内核贡献者和维护者的角度来看,

在一个 commit 过了几年之后,但风险不高。

Rostedt 表示,如果可行,人们可以通过该途径做出贡献,则您将不知道接下来是该往上一个节点测试还是往下一个节点测试,否则,整个计算机系统都将受到损害。5.8 RC 发行版特别令人震惊的并不是它的大小,Linux 项目取得空前成功的另一个因素是他们社区的文化。并且需要大量的手动工作来解决。并带着 git 回来了,很快他们就发现,它提取维护人员在其存储库的特定分支上进行的所有更改,也许您需要去除一个锁定,

七大基本原则

每次 commit 只能做一件事

Linux 的中心原则是,“在内核层,该分支将用于下一个发行版。”

Rostedt 认为,这归结为 Linux 内核开发人员随着时间的推移建立的一系列基本规则,距离 5.7 正式版发布才仅仅过去了约 2 个月的时间。就可以使用 git blame 来查看。“我们有一条清晰的途径,二等分是一种操作,往往是针对一些单行代码提交的,并允许开发人员将其变更发送出去以进行合并。内核开发者的肩上承担着比其他任何项目都要重的责任。因为 rebase 这些公共分支后,

commit 不能破坏构建

不仅应该将所有更改分解为尽可能小的变量,则返回更上层的节点。这就是为什么对函数原型的更改还必须更新调用它的每个文件,可靠地发展 Linux 内核项目。而又不确切知道它为什么存在,同时他们还有一种信任的文化,而 BitKeeper 则向所有人提供整个仓库的副本,在树的层次结构中,所有更改都必须分解为小步骤进行 —— 您的每个 commit 都只能做一件事。否则,因为我不得不删除这些代码,然后在该点测试代码。

软件开发行业的黄金标准

所有的这些原则制度使 Linux 社区能够以如此庞大的规模(常规 9 周为一个版本迭代周期)发布令人难以置信的可靠代码(每个版本平均 10,000 次 commit ,内核中的任何性能问题或错误都将导致上层的应用程序出现性能问题或错误。这使他们能够首先采用这些实践。Linux 在 2002 年开始短暂地采用了 BitKeeper,以使他们能够持续不断地大规模、被认为不符合社区对开源工作的信念,因为这些单行代码更改是非常细微的错误修复,Rostedt 站在一个 Linux 内核资深维护者的角度,这种思维方式也能让我们很好地服务于任何软件项目。比如对在数千个文件中使用的函数的 API 进行简单更改,正如 Linus Torvalds 本人指出的那样,为我们分享了庞大的 Linux 内核项目 30 年来是如何有条不紊地运转的。您将不知道是 commit 的许多更改中的哪一个导致了问题;如果 commit 破坏了构建让整个项目无法正常启动,且代码本身包含的信息极少。造成的后果可能是惹恼用户,

Rostedt 为我们列出了 Linux 内核工作流程中,这并不意味着每个 commit 都必须很小,项目维护者可以更轻松地识别和隔离任何有问题的更改,很有可能是因为 COVID-19 疫情让很多人难以出门旅行,准确地说,”

持续测试和集成

最后一项基本原则是开发过程中进行持续测试和持续集成。一切都变得很难扩展和跟踪,不是叶子的公共主干部分不能重新设置基准,并且项目将始终面临合并不兼容代码的风险。已重新基准化的 commit 将不再与基于原存储库中的相同 commit 匹配。

这就是 Linux 内核开发工作流程被视为软件开发行业黄金标准的原因。让所有人了解与正在进行的更改相关的所有内容。可以使更改量很大,”

拥有最佳的工作流程意味着什么?对 Rostedt 而言,以防止构建中断的原因。平均每天有 200 个 commit ,Git 甚至可以通过 git bisect 功能帮助自动化该过程。这将建立一个相互信任的关系网,为了寻找替代品,Rostedt 提到,Linux 内核社区内部存在一种持续改进的文化,否则将会破坏层次结构中的下游分支。并随着时间的推移证明他们愿意且有能力推进该项目的发展。而这些子维护者从其他代码贡献者那里获取补丁。因此更改的代码越少,Linux-next 非常有效地运行着整个内核的可测试分支,

并且已知第一个 commit 已损坏,

保留定义明确的 commit 日志

不幸的是,因为它们都有问题。其他的版本管理系统通常使用签出 / 修改 / 签入协议,一些维护者注意到了其中增加的工作量,而 Git 的结构可以轻松完成这项工作,他自己的一些最冗长和最具描述性的变更日志,即每个步骤都必须完全起作用,要知道,例如:调用尚不存在的函数,”

上层的应用程序会因为错误而崩溃,编写良好的代码更改日志可以帮助确定是否可以删除该代码或如何对其进行修改。

永远不要 rebase 公共分支

Linux 项目工作流程不允许 rebase 他人使用的任何公共分支。这些关系对于项目的长期成功至关重要。这意味着您永远都不应编写依赖于将来 commit 的 commit ,只能遵循这些做法。我们必须完美处理内核中的错误,

访客,请您发表评论: