Wasm 玩出花?在浏览器中运行虚拟机!

系统 浏览器
WebVM 和我们平时看到的传统的 WebShell 是完全不一样的,这个 WebVM 是没有服务器的,它单纯依赖于 HTML5/WebAssembly 就可以独自在浏览器客户端中运行一个基于 Debian 的完整虚拟机。

最近在 Github 上看到了一个挺有意思的项目:运行在浏览器环境中的虚拟机:WebVM。

传统意义上的虚拟机(VM)是一种创建于物理硬件系统(位于外部或内部)、充当虚拟计算机系统的虚拟环境,它模拟出了自己的整套硬件,包括 CPU、内存、网络接口和存储器,它依然需要运行在一个服务器上。

而 WebVM 和我们平时看到的传统的 WebShell 是完全不一样的,这个 WebVM 是没有服务器的,它单纯依赖于 HTML5/WebAssembly 就可以独自在浏览器客户端中运行一个基于 Debian 的完整虚拟机。

WebVM 是基于 CheerpX 实现的,CheerpX 是基于 Cheerp 编译器实现的... 别着急,我们先从 Cheerp 开始看, ~

Cheerp

WebAssembly 我们都知道,是一种二进制指令格式,简称为 Wsam,它可以运行在适用于堆栈的虚拟机上。WebAssembly 存在的意义就是成为编程语言的可移植编译目标,让在 Web 上部署客户端和服务端应用成为可能。简单来说,它可以让我们在 Web 环境中运行服务端代码。

而 Cheerp 就是一个可以生成 WebAssembly 的 C/C++ 编译器。

CheerpX

CheerpX 是一种 x86 到 WebAssembly 的虚拟化技术,声称可以完全在客户端运行任意的 x86 应用程序。

CheerpX 构建了一个基于 WebAssembly 的虚拟机来在浏览器中运行 X86 二进制文件。您可以使用它运行任何 REPL 环境。示例:https://repl.leaningtech.com/?python3

WebVM

而 WebVM,是一个在浏览器中运行的基于 Debian 的完整虚拟机,由 CheerpX 提供支持,由以下几部分组成:

  • CheerpX 作为 JavaScript API 执行引擎,特别是 cx.run(…) 这样的代码,用于启动 bash 进程。然后 bash 可以在用户键入命令时启动其他进程。
  • Xterm.js 作为主要的 UI 组件:Xterm.js 负责解释 vim 等应用程序使用的终端转义,并将用户输入发送回 CheerpX。输入通过应用程序的标准输入文件描述符提供给应用程序。
  • 一个 Debian buster 磁盘映像,采用 ext2 格式并安装了一堆软件包。它们被放在 CDN 上,这可以最大限度地提高可扩展性。

WebVM 的使命和愿景是让程序运行:

  • 无需修改;
  • 无需重新编译;
  • 完全客户端模式。

你可以在 WebVM 上尝试下面这些操作:

# 运行一个简单的 python 程序
python3 examples/python3/fibonacci.py
# 使用 gcc 编译一个简单的 C 示例
gcc -o helloworld examples/c/helloworld.c
# 运行!
./helloworld
# 转储代码,验证这实际上是一个 x86 二进制
objdump -d ./helloworld
# 编辑 helloworld.c 文件,然后再试一次
vim examples/c/helloworld.c

目录中提供了各种语言的示例文件 examples 。

最后

这个应用虽然离生产还有很大一段距离,但它确实让我看到了 Web 的无限可能。

Web 平台正在成为应用程序分发的主导平台。特别是自从 WebAssembly 标准化以来,这样的确实趋势已经越来越明显了,想象一下:一种新的编程语言一旦被开发出来,就会被所有现代浏览器支持,这可以持续满足大型 Web 应用程序的性能需求。

WebAssembly 为浏览器世界带来了真正的创新,以及视角和责任的转变。

责任编辑:赵宁宁 来源: code秘密花园
相关推荐

2022-04-25 10:26:11

Python代码浏览器

2021-07-31 12:58:53

PodmanLinux虚拟机

2021-09-12 12:00:12

浏览器LinuxWeb 应用

2022-05-04 11:07:32

虚拟机Linux

2023-11-17 14:06:43

2012-05-04 11:28:41

虚拟化KVM高性能

2021-12-14 10:54:31

TopK面试排序法

2009-08-12 14:15:12

VMware虚拟机配置DHCP服务器

2012-03-20 11:25:07

360手机浏览器

2009-03-26 15:35:22

detachedRIASilverligh

2022-01-04 09:02:24

浏览器命令行ttyd

2011-05-12 11:35:32

Oracle VM V虚拟机

2010-02-24 10:49:11

Python运行环境

2010-10-26 10:20:31

SUSE 11XenWindows虚拟机

2012-05-18 10:22:23

2015-10-20 14:03:44

虚拟机特性Windows 10

2021-09-30 09:40:32

Gitpod开源VS Code

2021-10-28 17:20:51

微软VS Code工具

2022-07-04 12:26:00

云原生开源

2021-02-16 12:50:13

服务器Linux浏览器
点赞
收藏

51CTO技术栈公众号