通过这个技术,浏览器可以运行Node.js、Rust、Python、PHP、C++、Java代码了!

近日,WebContainers 发布重要更新,WASI(WebAssembly 系统接口)已全面集成到 WebContainers 中。这是一个重要里程碑,它扩大了可以使用浏览器执行的操作,是 Web 开发的全新范例,允许运行大量原生应用,而无需考虑多种不同的架构。

WebContainers 是 StackBlitz 推出一种基于容器技术的 Web 应用环境,它提供了一个隔离环境来执行Web应用。WebContainers 也是第一个基于 WebAssembly 的系统,可以安全地在浏览器中启动 Node.js 环境。可以在 Stackblitz 的官网(https://stackblitz.com/)在线体验 webContainers 技术,官网已经初始提供了多种开发环境:

近日,WebContainers 发布重要更新,WASI(WebAssembly 系统接口)已全面集成到 WebContainers 中。这是一个重要里程碑,它扩大了可以使用浏览器执行的操作,是 Web 开发的全新范例,允许运行大量原生应用,而无需考虑多种不同的架构。

这也意味着,像使用 Rust、Python、PHP、C++、C 等语言编写的项目都可以在浏览器中运行了!

什么是 WASI?

多年来,JavaScript 是 Web 浏览器原生支持的唯一编程语言。然而,随着 Web 的不断发展,对紧凑、安全和高效执行的代码的需求不断增长。为了解决这个问题,Mozilla 在 2015 年透露,他们正在与谷歌、微软和苹果的工程师合作开发一种新标准,称为 WebAssembly,简称 Wasm。WebAssembly 是一种低级、类似汇编的语言,独立于任何特定平台运行。它使用压缩的二进制格式,旨在安全、快速地运行,提供接近本地执行速度的性能。此外,它还可以作为编译在 Web 上运行的代码的目标。

WebAssembly 用作编译目标,其中原生代码(例如 Rust、C++ 或 Golang)被编译到 WebAssembly。最初,它是为了在Web上运行 C++ 或 Rust 等语言而创建的。然而,现在它的应用范围已经扩大了。WebAssembly 支持多种编程语言,并且不仅限于 Web 浏览器。

现在,每个 WebAssembly 模块都在一个沙盒环境中运行,没有访问系统功能(例如文件和文件系统或网络)的权限。 这意味着 WebAssembly 的功能受到限制,必须通过JavaScript提供所有外部功能。

这就是 WASI 的用武之地。WASI 表示 WebAssembly 系统接口,充当一个桥梁,提供标准化接口,允许 WebAssembly 代码安全地与文件系统、网络、生成随机数等系统接口交互,而无需要通过JavaScript注入这些功能。这扩展了 WebAssembly 的功能,使我们能够使用任何编译为WebAssembly 的语言构建应用,并在任何可用运行时的地方运行它们,包括 WebContainers!

WASI将以多种颠覆性的方式影响你:

  • 速度和安全性:两者兼得。应用在保持安全沙盒环境的同时,以接近本地速度运行。
  • 可移植性:编译一次,到处运行!将本机代码编译为 WebAssembly,并在Web或其他地方运行它。
  • 多语言支持:许多编程语言如 C、C++、Rust 等都可以编译成WebAssembly 并使用 WASI 接口。这意味着可以使用其他语言编写系统级别的代码,而不只是Web所使用的JavaScript,从而提供更多的选项和灵活性。

实现以前不可能的事

WebAssembly 运行时

WASI的集成使得在WebContainers中可以使用wasm命令从终端执行 WebAssembly 或 WASI 编译的模块。这意味着可以将代码编译为WASI,将其上传到项目中,然后通过新的wasm命令运行它。这样就可以在终端上直接运行 WebAssembly 模块,无需使用复杂的工具或设置。

Python 支持

作为对可能性的示范,目前引入了对 Python 在 WebContainers 中的实验性支持。考虑到 Python 作为第三种最常用的编程语言,在浏览器的原生环境中一直缺失,这一点尤为重要。由于需要外部服务器进行执行,Python 的功能通常是分割的,导致开发体验不连贯。但现在不同了。随着 WASI 与 WebContainers 的集成,服务器和浏览器的领域进一步融合,为浏览器内开发开辟了新时代的道路。

重要的是,随着WASI不断演进和扩展其功能集,它将直接影响 WebContainers 中 Python 的功能。注意,这种Python的集成目前仍然处于实验阶段,这意味着它目前仅限于 Python 语言的核心功能。目前还未推出对 pip 的支持,即 Python 的软件包管理器,这意味着暂时还无法安装额外的 Python 软件包。可以编写、编辑和执行依赖于内置 Python 模块和功能的Python脚本,但对于依赖于外部库的更复杂项目则需要再等待一段时间。

原生 CLI 工具

除此之外,还扩展了 shell 的功能,添加了对jq的支持,这是一个本地命令行JSON处理器,可以轻松地切片、过滤、映射和转换结构化数据。可以在任何项目中从shell中使用它。

展望未来

虽然这些发展令人兴奋,但这只是个开始。WASI 仍在标准化的过程中,随着它的成熟,它将在 WebContainers 中释放更多的功能。目前正在开发一些令人兴奋的新功能,包括WebAssembly线程或WebAssembly垃圾回收等。StackBlitz 的野心是为其他流行语言添加实验性支持,特别是对 Ruby 和 PHP 的实验性支持。

相关推荐
郝学胜-神的一滴14 小时前
Linux命名管道:创建与原理详解
linux·运维·服务器·开发语言·c++·程序人生·个人开发
晚风(●•σ )14 小时前
C++语言程序设计——11 C语言风格输入/输出函数
c语言·开发语言·c++
恒者走天下15 小时前
秋招落定,拿到满意的offer,怎么提高自己实际的开发能力,更好的融入团队
c++
天若有情67316 小时前
【c++】手撸C++ Promise:从零实现通用异步回调组件,支持链式调用+异常安全
开发语言·前端·javascript·c++·promise
学困昇16 小时前
C++中的异常
android·java·c++
q***318316 小时前
Windows安装Rust环境(详细教程)
开发语言·windows·rust
合作小小程序员小小店17 小时前
桌面安全开发,桌面二进制%恶意行为拦截查杀%系统安全开发3.0,基于c/c++语言,mfc,win32,ring3,dll,hook,inject,无数据库
c语言·开发语言·c++·安全·系统安全
Codeking__17 小时前
C++ 11 atomic 原子性操作
开发语言·c++
crescent_悦17 小时前
PTA L1-020 帅到没朋友 C++
数据结构·c++·算法
卡提西亚17 小时前
C++笔记-34-map/multimap容器
开发语言·c++·笔记