多年以来,Google 一直在开发 Fuchsia,这是一种明显不基于 Linux 的操作系统。针对 Fuchsia OS 的最新提议显示了这种「非 Linux」操作系统能够运行「未经修改」的 Android 和 Linux 程序。
开发一个全新的操作系统,尤其是开发 Fuchsia 这样从头开始构建的操作系统的最大问题之一就是,人们理所当然地希望能够在新的操作系统上运行自己喜欢的应用程序。以 Fuchsia 为例,同样是出自 Google 之手,Fuchsia 是 Chrome OS 和 Android 系统的后继者,人们自然希望能够同时运行 Android 应用程序、Linux 应用程序以及 Fuchsia 原生的应用程序。
到目前为止,Fuchsia 能与 Chrome OS 当前在虚拟机中运行完整的 Linux 实例同样的方式来运行 Linux 应用程序。由于有一个名为 arcvm 的项目,Chrome OS 甚至可以使用相同的策略来运行 Android 应用程序。
但是,采用虚拟机的方法也有一些缺点。首先,在「主机」(Fuchsia)和「访客」(Android)之间管理文件可能很棘手或麻烦。此外,由于 Fuchsia 强调安全性,因此它会尽可能地使程序之间彼此隔离。为了保持 Linux 应用程序也能有相同的隔离级别,Fuchsia 可能需要运行多个虚拟机,因此会大幅降低性能。
本周,一项针对 Fuchsia 运行 Linux 和 Android 程序的替代解决方案的提案被正式提出。Fuchsia 不再运行 Linux 系统本身,取而代之的是一个名为「Starnix」的系统,该系统将在 Linux 内核指令和 Fuchsia Zircon 内核指令之间进行翻译。
因此,通过这种方式,Linux 应用程序将无需通过虚拟机运行 Linux 操作系统再运行软件的方式即可直接使用。又由于 Android 也同样是基于 Linux 开发而来的,Fuchsia 也将能够直接运行 Android 应用程序。
由此可见,Google 可能打算让 Fuchsia 能够深度支持 Android 应用程序,而不会出现任何例外情况,例如使用 Android NDK 编写 C 或 C++ 的应用程序。当然,从长远来看,Starnix 仅用作权宜之计,以允许 Google 的 Fuchsia 操作系统在等待开发人员将其应用程序移植到新操作系统时可以更广泛地使用。在任何情况下,原生 Fuchsia 应用程序的性能都应比通过 Starnix 运行的 Linux 或 Android 应用程序更好。
Fuchsia 的 Starnix 目前才处于提议阶段,需要做大量工作才能使任何类似 Android/Linux 到 Fuchsia/Zircon 的兼容性成为可能。而且这项提议仍然有失败的可能性,届时 Fuchsia 还可以退回使用虚拟机来满足 Linux 和 Android 的需求。
Google 最近已经开放了该项目,以征询来自开源社区的贡献。如果在 Fuchsia 中增加 Linux 和 Android 的兼容性听起来很吸引你,那么可以点击链接为 Fuchsia 做出自己的贡献。