FOSDEM 2025:Rust在Linux中蓬勃发展,尽管面临强烈反对

发布时间 - 2025-04-17 00:00:00    点击率:

越来越多的开发者和内核维护者青睐 rust,但在内核开发社区中,支持 rust 和支持 c 的阵营之间存在争议。

Rust 最终应该在 Linux 内核中取代 C 代码。然而,这可能需要几十年的时间才能实现。但在短期内,预计会看到 Rust 代码在 Linux 中的激增,从边缘设备到微软的 Xbox 都有支持,尽管包括一些 Linux 内核维护者在内的许多人对此表示不满。

Rust 在内核中的使用越来越普遍,并且已经证明其在 Linux 内核和其他领域的各种用例中优于 C,特别是在内存安全方面。然而,Rust 相对于内核中的 C 语言并非没有风险,更不用说其非常陡峭的学习曲线。越来越多的开发人员和内核维护人员喜欢 Rust,但内核开发社区中存在着支持 Rust 和支持 C 阵营之间的争论,这种争论在本周持续进行,双方进行了激烈的交流。

Rust 相关的动态是 FOSDEM (欧洲自由和开源开发者会议) 的一个主要讨论主题,这是一个由志愿者在布鲁塞尔自由大学 (ULB) 组织的领先开源会议。在数十个与 Rust 相关的演讲中,由 Miguel Ojeda 做的同名演讲 Rust for Linux 脱颖而出,他负责维护该项目,并且是 Linux 基金会技术咨询委员会的成员。除了讨论 Rust for Linux 项目外,他还介绍了发行工具链的状态、Rust 的稳定性,以及重要的是,你如何为内核的开发做出贡献。Rust for Linux 计划还在与 GCC 和其他组织合作,以促进在 Linux 内核中添加直接内存访问 (DMA) Rust 抽象。

Google 一直是将 Rust 添加到内核以在 Android 手机中运行 Linux 的坚定支持者。在内核中使用 Rust 被认为是避免与 C 和 C++ 代码相关的内存漏洞并为 Android 操作系统增加更多稳定性的一种方式。“Google 希望用 Rust 代码替换 C 代码,这只代表内核的一小部分,但会产生巨大的影响,因为我们谈论的是数十亿部手机,”Ojeda 在他的演讲后告诉我。

除了 Google 之外,随着 Rust 获得更多的架构支持以及“维护者对它越来越满意”,Rust 的采用和热情也在增加,Ojeda 告诉我。“维护者已经告诉我,如果可以的话,他们现在就开始编写 Rust,”Ojeda 说。“如果他们可以放弃 C,他们就会这样做。”

Ojeda 在他的演讲中没有提到的是,最近那些不愿在容器中混合 C 和 Rust 代码的维护者遭到了强烈反对。9 月,Linux 的创建者 Linus Torvalds 在他的 Open Source Summit 主题演讲中将这场争议描述为具有“几乎宗教战争的意味”。Torvalds 随后表示,虽然这场争议涉及健康的争论,但有些争论正变得非常消极。

问题在于 C 语言和 Rust 语言在跨语言边界提交更改时存在的文化冲突。代表 Rust 人员修改 C 接口可能从 Rust 的角度来看是有意义的(反之亦然),而 C 人员则寻求 Rust 贡献来插入 C。

这场争议可以追溯到三年多前,当时有人提出 Rust 具有 C 所不具备的某些安全优势,可以成为内核的一部分并有可能取代它。尽管如此,该项目并没有停滞不前。

例如,现在著名的缓冲区溢出攻击或可以使用 C 和 CPU 生成的漏洞几乎已经过时。虽然 Rust 提供了一些安全特性和缺点,但与更容易掌握的 C 相比,它也更难学习。

在最近的 Rust 和 C 阵营之间的一次交流中,软件工程师和 Linux 内核维护者 Christoph Hellwig 在 1 月初的一封电子邮件中写道:“kernel/dma 中不要有 Rust 代码。”他的信息是为了回应在 Linux 内核中为 DMA API 添加 Rust 补丁的请求。一月份,在最近的一次来回讨论中,在周三的 FOSDEM 周边会议前夕,讨论进一步升温。

(2016 年,Hellwig 在一起针对当时的 VMware 的诉讼中败诉,声称 vSphere 侵犯了一个开源许可证。汉堡的德国法院驳回了该诉讼。)

上周,Hellwig 拒绝了 Red Hat 工程师和内核贡献者 Danilo Krummrich 对为 C API 添加 Rust 抽象的支持。

Krummrich 提出,DMA 一致性分配器的 Rust 抽象层应作为“单独的组件”进行维护。Hellwig 上周回复了 Krummrich 的提议:

Rust 浪潮在争议中,人们一直在大声支持 Ojeda。他的大部分讨论还涵盖了内核中 Rust 倡导者发表的声明,从内核的首席开发人员(包括 Linux 创建者 Linus Torvalds 本人)到 Red Hat、Samsung、Google、Microsoft 等公司的技术负责人。

在他的演讲中,Ojeda 重申了他之前在 2025 年给 Torvalds 的电子邮件中写的一句话,他说这句话至今仍然适用:

“通过在 Linux 内核中使用 Rust,我们希望:

由于下面提到的语言特性,用 Rust 编写的新代码可以降低内存安全错误、数据竞争和总体逻辑错误的风险。由于 Rust 的安全子集,维护人员更有信心重构和接受模块的补丁。由于基于现代语言特性且有详细文档支持的更易于推理的抽象,新的驱动程序和模块变得更容易编写。由于使用了现代语言,更多的人参与到内核的开发中。通过利用 Rust 的工具链,我们持续确保项目中已建立的文档规范得到执行。例如,我们要求对所有公共 API、安全性前置条件、unsafe 代码块和类型不变量都进行文档说明。与此同时,使用 Rust 和 C 之间的选择不一定是二选一的问题。我认为,C 将无限期地用于许多内核层和规范中。毕竟,古老的格言适用:‘如果它没有坏,那就不要修理它。’”

Ojeda 告诉我:“有些维护人员不想放弃 C。但是何时不再使用 C 取决于成熟度。这取决于底层和架构的成熟度,而架构的成熟度各不相同。”


# linux  # 操作系统  # 工具  # c++  # red  # 2025  # rust  # 架构  # for  # 接口  # android  # microsoft  # xbox  # 软件工程  # 重构  # 告诉我  # 的是  # 这场  # 开源  # 但在  # 文档  # 更容易  # 该项目  # 布鲁塞尔  # 开发人员 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: 英语简历制作免费网站推荐,如何将简历翻译成英文?  Laravel如何实现图片防盗链功能_Laravel中间件验证Referer来源请求【方案】  WordPress 子目录安装中正确处理脚本路径的完整指南  Laravel如何使用Spatie Media Library_Laravel图片上传管理与缩略图生成【步骤】  如何在万网利用已有域名快速建站?  详解jQuery中的事件  Laravel如何理解并使用服务容器(Service Container)_Laravel依赖注入与容器绑定说明  Laravel怎么生成二维码图片_Laravel集成Simple-QrCode扩展包与参数设置【实战】  如何在IIS中新建站点并配置端口与物理路径?  国美网站制作流程,国美电器蒸汽鍋怎么用官方网站?  EditPlus中的正则表达式 实战(4)  零基础网站服务器架设实战:轻量应用与域名解析配置指南  安克发布新款氮化镓充电宝:体积缩小 30%,支持 200W 输出  如何获取免费开源的自助建站系统源码?  html5源代码发行怎么设置权限_访问权限控制方法与实践【指南】  linux top下的 minerd 木马清除方法  如何批量查询域名的建站时间记录?  网站建设整体流程解析,建站其实很容易!  Laravel如何配置中间件Middleware_Laravel自定义中间件拦截请求与权限校验【步骤】  如何为不同团队 ID 动态生成多个“认领值班”按钮  Win11摄像头无法使用怎么办_Win11相机隐私权限开启教程【详解】  Laravel安装步骤详细教程_Laravel环境搭建指南  电商网站制作多少钱一个,电子商务公司的网站制作费用计入什么科目?  北京网站制作的公司有哪些,北京白云观官方网站?  标题:Vue + Vuex 项目中正确使用 JWT 进行身份认证的实践指南  Win11应用商店下载慢怎么办 Win11更改DNS提速下载【修复】  Laravel如何处理和验证JSON类型的数据库字段  佐糖AI抠图怎样调整抠图精度_佐糖AI精度调整与放大细化操作【攻略】  如何做网站制作流程,*游戏网站怎么搭建?  昵图网官方站入口 昵图网素材图库官网入口  Laravel Fortify是什么,和Jetstream有什么关系  如何在云虚拟主机上快速搭建个人网站?  EditPlus中的正则表达式实战(5)  百度浏览器网页无法复制文字怎么办 百度浏览器复制修复  Java解压缩zip - 解压缩多个文件或文件夹实例  如何在HTML表单中获取用户输入并结合JavaScript动态控制复利计算循环  如何快速搭建高效WAP手机网站吸引移动用户?  Javascript中的事件循环是如何工作的_如何利用Javascript事件循环优化异步代码?  香港服务器网站卡顿?如何解决网络延迟与负载问题?  为什么php本地部署后css不生效_静态资源加载失败修复技巧【技巧】  油猴 教程,油猴搜脚本为什么会网页无法显示?  图册素材网站设计制作软件,图册的导出方式有几种?  如何用搬瓦工VPS快速搭建个人网站?  如何快速搭建FTP站点实现文件共享?  详解Android——蓝牙技术 带你实现终端间数据传输  Laravel如何使用查询构建器?(Query Builder高级用法)  Laravel如何处理跨站请求伪造(CSRF)保护_Laravel表单安全机制与令牌校验  Laravel如何使用Blade组件和插槽?(Component代码示例)  Edge浏览器怎么启用睡眠标签页_节省电脑内存占用优化技巧  Laravel Eloquent模型如何创建_Laravel ORM基础之Model创建与使用教程