通过这个技术,浏览器可以运行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 的实验性支持。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/109401.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

应用在红外线遥控领域中的心率传感信号接收芯片

红外遥控是一种无线、非接触控制技术,具有抗干扰能力强,信息传输可靠,功耗低,成本低,易实现等显著优点,被诸多电子设备特别是家用电器广泛采用,并越来越多的应用到计算机和手机系统中。 红外线…

探讨Acrel-1000DP分布式光伏系统的设计与应用-安科瑞 蒋静

摘 要:分布式光伏发电特指在用户场地附近建设,运行方式以用户侧自发自用、余电上网,且在配电系统平衡调节为特征的光伏发电设施,是一种新型的、具有广阔发展前景的发电和能源综合利用方式,它倡导就近发电,就…

视频太大怎么压缩变小?三分钟学会视频压缩

随着科技的不断发展,视频已经成为了我们日常生活中不可或缺的一部分,然而,大尺寸的视频文件常常会给我们带来诸多困扰,例如发送不便、存储空间不足等等,那么,如何将这些过大的视频文件压缩变小呢&#xff1…

新一代开源语音库CoQui TTS冲到了GitHub 20.5k Star

Coqui TTS 项目介绍 Coqui 文本转语音(Text-to-Speech,TTS)是新一代基于深度学习的低资源零样本文本转语音模型,具有合成多种语言语音的能力。该模型能够利用共同学习技术,从各语言的训练资料集转换知识,来…

2023年中国熔盐储能装机量、新增装机量及行业投资规模分析[图]

熔盐储能是一种可以传递能量、长时间(6-8h)、大容量储能的技术路径,作为传热介质可以实现太阳能到热能的转换,作为储能介质可以实现将热能和电能的双向转换,可以很好的适应和解决以上两大矛盾。因此,熔盐储…

基于SVM+Webdriver的智能NBA常规赛与季后赛结果预测系统——机器学习算法应用(含python、ipynb工程源码)+所有数据集(一)

目录 前言总体设计系统整体结构图系统流程图 运行环境Python环境Jupyter Notebook环境PyCharm环境MATLAB环境 模块实现1. 数据预处理1)常规赛数据处理2)季后赛数据处理 相关其它博客工程源代码下载其它资料下载 前言 本项目使用了从NBA官方网站获得的数…

[Java]0.1+0.2不等于0.3 !!一分钱问题与解决方案

一、原因 原因很简单,计算机存储和计算数组都是用二进制, 而大部分小数转二进制的时候,就丢失精度了。 0.1、0.2、0.3这些小数在二进制里都是循环小数,计算机不可能存储无限循环小数,所以只能截取一部分,导…

中文连续视觉语音识别挑战赛

视觉语音识别,也称唇语识别,是一项通过口唇动作来推断发音内容的技术。该技术在公共安全、助老助残、视频验真等领域具有重要应用。当前,唇语识别的研究方兴未艾,虽然在独立词、短语等识别上取得了长足进展,但在大词表…

从创业者的角度告诉你AI问答机器人网页的重要性

在数字化时代,创业者面临着越来越多的挑战。而AI问答机器人网页正成为创业者们的必备工具。它可以提供即时客户支持、降低运营成本,并实现全天候服务。接下来,我将从创业者的角度阐述一下,AI问答机器人网页为什么那么重要&#xf…

快速自动化处理JavaScript渲染页面的方法

目录 一、使用无头浏览器 二、使用JavaScript渲染引擎 三、使用前端框架工具 随着互联网技术的不断发展,JavaScript已经成为Web开发中不可或缺的一部分。然而,在自动化处理JavaScript渲染页面方面,却常常让开发者感到头疼。本文将介绍一些快…

Nessus已激活,New Scan按钮不可点击

刷新后会给出下面的提示 Plugins are compiling. Nessus will be limited until compilation is complete. 因为插件编译中,所以扫描功能被禁用了。 查看编辑进度,鼠标放到两个循环箭头上即可查看。

6.4 图的存储结构

思维导图: 前言: --- **6.4 图的存储结构** - **核心问题**:由于图的结构复杂性,我们不能仅仅依赖于元素在存储区的物理位置来表示它们之间的关系。 - **邻接矩阵**: - **基本思路**:虽然图没有顺序存…

[Machine Learning][Part 6]Cost Function代价函数和梯度正则化

目录 拟合 欠拟合 过拟合 正确的拟合 解决过拟合的方法:正则化 线性回归模型和逻辑回归模型都存在欠拟合和过拟合的情况。 拟合 来自百度的解释: 数据拟合又称曲线拟合,俗称拉曲线,是一种把现有数据透过数学方法来代入一条…

PHP框架开发实践 | 1024 程序员节:通过index.php找到对应的controller是如何实现的

🏆作者简介,黑夜开发者,CSDN领军人物,全栈领域优质创作者✌,CSDN博客专家,阿里云社区专家博主,2023年6月CSDN上海赛道top4。 🏆数年电商行业从业经验,历任核心研发工程师…

STM32CubeMX之DMA辅助串口数据接收

1.DMA辅助串口数据接收 1.1 DMA简介 直接存储器存取(DMA)用来提供在外设和存储器之间或者存储器和存储器之间的高速数据传输。无须CPU干预,数据可以通过DMA快速地移动,这就节省了CPU的资源来做其他操作。   两个DMA控制器有12个通道(DMA1有7个通道&am…

什么是网络爬虫,爬虫的机制是那些

网络爬虫(也称为网页蜘蛛、网络机器人或网页追逐者)是一种按照预设规则,自动抓取万维网信息的程序或脚本。它们广泛应用于搜索引擎、数据挖掘、竞争情报、价格监测等各种互联网应用中。 爬虫机制是爬虫程序或机器人用来访问、抓取、索引以及…

2023年中国清净剂行业需求现状及前景分析[图]

清净剂用于中和由于燃烧和润滑油氧化产生的酸性物质,并清除颗粒和污物。这类杂质在油中的溶解度有限,因此,清净剂可以最大程度减少沉积物的生成,降低污染,提高环保排放标准。成熟产品有磺酸盐、硫化烷基酚盐、烷基水杨…

yolov作者简介

作者简介 作者叫Joseph Redmon,在谷歌学术上搜索作者的简介。 地址:‪Joseph Redmon‬ -巨人学术搜索‬‬ (cljtscd.com) 他提出了最著名的YOLO算法。其中YOLOV1的引用量达到了40287次。 gitihub地址:github地址 主页:个人主页

ims-ui项目搭建

node版本: npm版本: 创建vite项目: npm create vitelatest 使用的vite版本为: 安装router4,安装命令如下: npm install vue-router4 安装pinia,安装命令如下: npm install pinia 安装Pinia持…

【Linux】adduser命令使用

我们经常在linux系统中创建用户。有时候用的是 useradd 有时候用的是 adduser ,好混乱啊到底用哪个啊。今天咱们一起来学习一下。 adduser与useradd的区别 useradd 命令是内置的 Linux 命令,在任何 Linux 系统中都可用。然而,使用这种低级…