红帽白皮书新鲜出炉!点击获取,让你的云战略更胜一筹! 了解详情
写点什么

用 Rust 重写 Linux 内核,这可能吗?

  • 2021-03-25
  • 本文字数:1704 字

    阅读完需:约 6 分钟

用Rust重写Linux内核,这可能吗?

众所周知,Linux 是 C 语言的代言人。但是,时代变了,Rust 正在兴起并赢得越来越多人的支持,它开始逐渐扮演 Linux 系统语言的角色。


在 2020 年 Linux Plumbers 峰会上,开发人员认真考虑过将 Rust 语言用于 Linux 内联代码的想法。此外,已经有很多 Linux 中的 Rust 内容被推向市场。比如,AWS 在 2020 年发布了 Bottlerocket,这是一种专为运行容器而打造的基于 Linux 的开源操作系统,其中包含大量的 Rust 代码。


另一个例子则与 Sylvestre Ledru 有关。他白天的身份是 Mozilla 的主管,而晚上却是 Debian Linux 开发人员。 Ledru 已经使用 LLVM 编译器基础架构及其 Clang C 语言前端和工具链基础架构,将一个 Rust 版本的 Coreutils 移植到了 Linux 中。据了解,Coreutils 是 GNU Shell 核心实用程序。基于这些内容,他已经启动了 Linux 并运行了一些最受欢迎的 Debian 软件包。虽然 Ledru 承认这一平台还没有准备好投入生产,但经过很多繁重的工作后,它现在已经可以使用了。总有一天,它会发展到替代 GNU Coreutils 的地步。

挺进 Linux 世界,Rust 机会在哪?


Rust 之所以受欢迎,是因为开发人员用 Rust 更容易编写出安全的软件。一直以来,安全性深深困扰着微软和谷歌等公司。此前,微软的研究人员称,该公司每年修复的漏洞中有 70% 与内存安全有关。谷歌的调查也发现,Chrome 代码库中所有严重的安全漏洞,70% 是内存管理的安全漏洞。


这些安全问题正好可以使用 Rust 来解决。AWS 产品经理 Samartha Chandrashekar 表示,“Rust 有助于确保线程安全,并防止与内存相关的错误,例如可能导致安全漏洞的缓冲区溢出“。


据悉,2019 年 Linux 安全峰会揭示,大约三分之二的 Linux 内核漏洞来自内存安全问题。


从理论上讲,Rust 可以使用本质上更安全的应用程序接口(API)完全避免这些漏洞。


那么,关于 Linux 中的 Rust 地位,Linux 开发人员 Nelson Elhage 总结道:Linux Rust 的支持者并不是“提议将 Linux 内核用 Rust 重写;他们只是努力想做到让新的代码可以用 Rust 来编写。Rust 支持的三个潜在关注点包括利用内核中的现有 API、架构支持”,以及处理 Rust 和 C 之间的应用程序二进制接口(ABI)兼容性。

Linux 之父:驱动程序可能率先 Rust 化


当然,Rust 能否替代 C 语言,主宰 Linux 世界?Linux 之父 Linus 和 Linux 稳定内核的维护者 Greg Kroah-Hartman 或许最有发言权。


Linus 一直在“等待与观察”。他说:“我对这个项目很感兴趣,但我认为它是由非常热衷于 Rust 的人们推动的,并且我想看看它在实践中的效果究竟如何。”


Linus 表示,“绝不会推动 Linux 中的 Rust 运动。但是,鉴于 Rust 的优势,我愿意接受它。”


Linus 认为,Rust 的首要目标似乎是驱动程序,这是因为在那里,你可以找到许多不同的可行目标,并且内核的这些部分相当小巧且独立。对某些人来说,这可能没那么有趣,但它是非常明显的目标。


在他看来,首先考虑驱动程序的另一个原因是“任何对驱动程序的初期尝试都发生在架构层面。很多驱动程序只关联了少数几个目标架构,因此 Rust 代码在某些架构上不被支持的问题在这里并不算什么大事。”


Linux 稳定内核的维护者 Greg Kroah-Hartman 认同 Linus 的说法,“驱动程序可能是这类尝试的首选领域,因为它们是内核源代码依赖树的'末端枝叶'。它们依赖于核心内核功能,但没有任何内容依赖它们”。


Linus 知道有些人完全不喜欢用户空间中有 Rust 的存在。“人们在抱怨用户空间中的'Rust 化'对未来的内核来说并不是什么好迹象,但究竟如何,我们可以拭目以待。内核与用户空间项目是不一样的——内核在某些方面更难处理(我们使用了很多非常奇怪的头文件,这些文件推动了可以称为“C”的边界),但是在其他许多方面又更容易(主要因为内核是完全自包含的,因此最终二进制文件不依赖其他项目”。


“一切都归结为如何将用 C 编写的内核核心结构和长期规则之间的交互映射到 Rust 结构和长期规则中,以让 Rust 编写的驱动程序能够正确使用它们。想要将所有这些组织起来的开发人员将需要大量的用心努力,我祝他们好运。”Greg Kroah-Hartman 补充说。

写在最后:


目前,几乎可以肯定,用 Rust 重写 Linux 这样的事短时不会发生,但是 Linux 中用户空间程序和驱动程序却有可能率先 Rust 化。

2021-03-25 14:336116
用户头像
万佳 前InfoQ编辑

发布了 677 篇内容, 共 332.6 次阅读, 收获喜欢 1793 次。

关注

评论 2 条评论

发布
用户头像
轮子,任何时候都要造,不造不行,你们想想,你带着老婆,出了城,吃着火锅还唱着歌,突然就被新手取代了! 所以,有輪子造的日子,才是好日子! (出自讓子彈飛一會)
2021-04-01 16:00
回复
用户头像
不要重复造轮子
2021-03-31 10:13
回复
没有更多了
发现更多内容

边缘计算应用领域

lenka

5月日更

拍照被嫌弃,他用分布式技术开发了一款自拍神器

科技汇

招行票付通对接总体流程

try catch

支付 商业票据

阿里专家离职带出来的Java面试全秘籍,我看了三个月,就收到了京东的offer

Java 程序员 架构 面试 计算机

对账模块和赊购退款、还款流程

try catch

支付 退款 对账 赊购

apache dubbo 自定义全局统一的异常处理器

try catch

后台开发:核心技术与应用实践 — C++

奔着腾讯去

c++ 面向对象 服务器开发 C++后台开发

超详细!看完阿里大师的Java成长笔记后,差距真不是一点点

Java 程序员 架构 面试

11 步完美排查服务器! 是否已经被入侵

Thrash

安全

逻辑回归 - DAY 11

Qien Z.

线性回归 逻辑回归 5月日更 逻辑函数

中国数字货币释放利好消息!

CECBC

CODING 首届金融科技技术交流闭门会议顺利召开

CODING DevOps

DevOps DevSecOps 代码安全

多租户如何独立进行开发测试?

paraboy1

521的祝福-北爱的回忆

数据一哥

520单身福利 520 单身福利

未来每个人的生活可能都会离不开区块链

CECBC

来自一个DBA的肺腑之言

BinTools图尔兹

数据库 运维自动化 数据安全 dba

支付网关整体架构图

try catch

支付 支付网关

波特五力模型

石云升

创业 战略 职场经验 5月日更

智慧公安微警务APP搭建,公安信息化建设

网络攻防学习笔记 Day21

穿过生命散发芬芳

5月日更 网络攻防

只需三步,开启 API 文档简洁之美

CODING DevOps

API

专访新腾数致研发总监金涛:新思想、新工具与新效率

CODING DevOps

敏捷开发 研发团队

区块链专家与媒体面对面 | “区块链让数据产生价值”

CECBC

牛!大佬都在用。Ngrok + Metasploit = 暂时性隐蔽C2

Thrash

安全

【得物技术】统一OLAP查询平台之语义层

得物技术

OLAP 查询 得物技术 平台 语义

数据仓库如何确定主题域?

数据社

数据仓库 5月日更

C#常用特性和快捷键

fox

520单身福利

“产学合作,协同育人”——安谋中国集成电路人才发展趋势沙龙圆满举行

脑极体

5分钟速读之Rust权威指南(七)

wzx

rust

显示器的未知之海:从电脑窗口到数字世界的Mate级探险

脑极体

架构学习笔记:架构设计3原则

风翱

架构 5月日更

用Rust重写Linux内核,这可能吗?_开源_万佳_InfoQ精选文章