0

0

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

看不見的法師

看不見的法師

发布时间:2025-04-17 14:54:11

|

739人浏览过

|

来源于php中文网

原创

越来越多的开发者和内核维护者青睐 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 周边会议前夕,讨论进一步升温。

天工大模型
天工大模型

中国首个对标ChatGPT的双千亿级大语言模型

下载

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

FOSDEM 2025:Rust在Linux中蓬勃发展,尽管面临强烈反对上周,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 重申了他之前在 2021 年给 Torvalds 的电子邮件中写的一句话,他说这句话至今仍然适用:

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

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

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

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
C++系统编程内存管理_C++系统编程怎么与Rust竞争内存安全
C++系统编程内存管理_C++系统编程怎么与Rust竞争内存安全

C++系统编程中的内存管理是指 对程序运行时内存的申请、使用和释放进行精细控制的机制,涵盖了栈、堆、静态区等不同区域,开发者需要通过new/delete、智能指针或内存池等方式管理动态内存,以避免内存泄漏、野指针等问题,确保程序高效稳定运行。它核心在于开发者对低层内存有完全控制权,带来灵活性,但也伴随高责任,是C++性能优化的关键。

13

2025.12.22

Rust异步编程与Tokio运行时实战
Rust异步编程与Tokio运行时实战

本专题聚焦 Rust 语言的异步编程模型,深入讲解 async/await 机制与 Tokio 运行时的核心原理。内容包括异步任务调度、Future 执行模型、并发安全、网络 IO 编程以及高并发场景下的性能优化。通过实战示例,帮助开发者使用 Rust 构建高性能、低延迟的后端服务与网络应用。

10

2026.02.11

Rust内存安全机制与所有权模型深度实践
Rust内存安全机制与所有权模型深度实践

本专题围绕 Rust 语言核心特性展开,深入讲解所有权机制、借用规则、生命周期管理以及智能指针等关键概念。通过系统级开发案例,分析内存安全保障原理与零成本抽象优势,并结合并发场景讲解 Send 与 Sync 特性实现机制。帮助开发者真正理解 Rust 的设计哲学,掌握在高性能与安全性并重场景中的工程实践能力。

225

2026.03.05

硬盘接口类型介绍
硬盘接口类型介绍

硬盘接口类型有IDE、SATA、SCSI、Fibre Channel、USB、eSATA、mSATA、PCIe等等。详细介绍:1、IDE接口是一种并行接口,主要用于连接硬盘和光驱等设备,它主要有两种类型:ATA和ATAPI,IDE接口已经逐渐被SATA接口;2、SATA接口是一种串行接口,相较于IDE接口,它具有更高的传输速度、更低的功耗和更小的体积;3、SCSI接口等等。

1926

2023.10.19

PHP接口编写教程
PHP接口编写教程

本专题整合了PHP接口编写教程,阅读专题下面的文章了解更多详细内容。

656

2025.10.17

php8.4实现接口限流的教程
php8.4实现接口限流的教程

PHP8.4本身不内置限流功能,需借助Redis(令牌桶)或Swoole(漏桶)实现;文件锁因I/O瓶颈、无跨机共享、秒级精度等缺陷不适用高并发场景。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

2395

2025.12.29

java接口相关教程
java接口相关教程

本专题整合了java接口相关内容,阅读专题下面的文章了解更多详细内容。

47

2026.01.19

android开发三大框架
android开发三大框架

android开发三大框架是XUtil框架、volley框架、ImageLoader框架。本专题为大家提供android开发三大框架相关的各种文章、以及下载和课程。

338

2023.08.14

C# ASP.NET Core微服务架构与API网关实践
C# ASP.NET Core微服务架构与API网关实践

本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

76

2026.03.11

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
php-src源码分析探索
php-src源码分析探索

共6课时 | 0.5万人学习

golang和swoole核心底层分析
golang和swoole核心底层分析

共3课时 | 0.2万人学习

Redis中文开发手册
Redis中文开发手册

共0课时 | 0人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号