Wasm 玩出花?在浏览器中运行虚拟机!
最近在 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 为浏览器世界带来了真正的创新,以及视角和责任的转变。
相关文章
- 在 Go 里用 CGO?这 7 个问题你要关注!
- 9款优秀的去中心化通讯软件 Matrix 的客户端
- 求职数据分析,项目经验该怎么写
- 在OKR中,我看到了数据驱动业务的未来
- 火山引擎云原生大数据在金融行业的实践
- OpenHarmony富设备移植指南(二)—从postmarketOS获取移植资源
- 《数据成熟度指数》报告:64%的企业领袖认为大多数员工“不懂数据”
- OpenHarmony 小型系统兼容性测试指南
- 肯睿中国(Cloudera):2023年企业数字战略三大趋势预测
- 适用于 Linux 的十大命令行游戏
- GNOME 截图工具的新旧截图方式
- System76 即将推出的 COSMIC 桌面正在酝酿大变化
- 2GB 内存 8GB 存储即可流畅运行,Windows 11 极致精简版系统 Tiny11 发布
- 迎接 ecode:一个即将推出的具有全新图形用户界面框架的现代、轻量级代码编辑器
- loongarch架构介绍(三)—地址翻译
- Go 语言怎么解决编译器错误“err is shadowed during return”?
- 敏捷:可能被开发人员遗忘的部分
- Denodo预测2023年数据管理和分析的未来
- 利用数据推动可持续发展
- 在 Vue3 中实现 React 原生 Hooks(useState、useEffect),深入理解 React Hooks 的