互联网技术 / 互联网资讯 · 2024年3月31日

使用Hippo进行WebAssembly编程

介绍

WebAssembly是一项非常有前途的新技术,微软的云原生计算团队对其Deis Labs子公司和Azure都非常感兴趣。随着新的WebAssembly工具迅速出现,您需要一个可以试用它们的环境。

这就是为什么Deis Labs发布其新的HIPpo WebAssembly平台如此重要的原因。就像Deis的许多工具一样,它是一种快速安装、管理和运行WebAssembly(WASM)代码的方式,无论是浏览器托管还是独立的WebAssembly系统接口(WASI)。将其内置通道与Git服务器结合使用,您可以在一个环境中制作和部署不同的版本,将生产、暂存和开发构建分开,同时仍然只需要一台HIPpo服务器。

您可以在HIPpo中托管多个应用程序。WebAssembly意味着默认情况下它们是沙盒的,需要明确的权限才能访问主机系统或外部设备。您的代码也是可移植的。一旦为WebAssembly编译,它将在任何WebAssembly系统上运行,无论是Windows、Linux或MacOS,还是Intel、RISC-V或ARM。HIPpo为您提供了一种构建一次、测试一次并在任何地方运行代码的方法。

在开发PC上设置HIPpo

尽管像HIPpo这样的工具非常适合云原生操作,但当前的开发人员版本仅在桌面系统上进行了测试。我决定在运行最新版本的WSL2并托管Ubuntu的Windows PC上试用它。Deis提供了在本地运行HIPpo的说明,以及MacOS和Linux系统的详细信息。

在WSL2 Ubuntu 20.04 LTS系统上获得运行HIPpo的先决条件存在一些问题。首先,我需要安装WAGI,即WebAssembly应用程序网关接口。这很容易安装,在其GitHub存储库中托管的可下载tarfile中有一个二进制文件。一旦下载、解压并移动到用户二进制目录,它就可以轻松运行。我借此机会安装了RUst,因为如果我必须重新编译任何Deis工具,我可能需要它。

这一步可能是WSL2上最困难的,因为它需要一份build-essential工具包的副本。Ubuntu 20.04没有正确的依赖集,所以我需要一个替代的包安装程序,它允许我将某些关键库降级到适当的版本。Stack Overflow的回答向我指出aptitude,这是apt的替代品,它允许您为安装选择适当的依赖项并允许它替换两个低级C库。我终于使用它的安装脚本安装了build-essential,为RUst做好准备。

什么是绑定?

将RUst安装为HIPpo安装的一部分的主要原因是为了Deis的WebAssembly打包工具Bindle。Bindle被描述为“聚合对象存储”系统。它的文档使用的比喻是“Binder是数字银器抽屉”。我们的银器抽屉里可能都有一些不同的物品,但我们都使用抽屉来分类和存放银器。Bindle对构成现代应用程序的工件做了很多相同的事情,同时根据应用程序的使用方式和使用位置,提供了对应用程序如何组合的一定程度的理解。

您可以拥有一个应用程序的Bindle描述,其中包含在资源受限的边缘主机(如Raspberry Pi)上进行稀疏安装以及位于公共云核心的高性能服务器所需的元素。应用程序主机中的Bindle客户端可以获取元素和依赖项并适当地部署它们。结果是一个以应用程序为中心的部署模型,它避免了使用存储库和智能描述将正确的代码交付到正确的环境的多次构建。

安装Bindle后,您可以运行它,使用默认设置设置本地Bindle服务器以供HIPpo使用。接下来,我安装了Node.js的,使用由微软提供的WSL说明。这需要使用curl下载nvm,然后运行它以安装最新和长期支持的Node.js版本。不要使用Ubuntu说明来安装节点;他们使用snap来安装它,并且在WSL2中并没有很好地支持snap。

您需要为任何HIPpo托管的RUst WebAssembly应用程序安装RUst的wasm32-wasi支持,以及yo-wasm Yeoman应用程序脚手架工具。这将允许您将RUst代码编译为WASI目标,准备在HIPpo中运行。

有了这些,我现在可以安装.NET 5,在安装.NET 5 SDK和运行时之前,首先设置对Microsoft的debian包存储库的支持。.NET运行时有两种选择:一种支持ASP.NET Core,另一种不支持。由于HIPpo是一个模型-视图-控制器Web应用程序,您应该使用ASP.NET版本的运行时。

构建和运行HIPpo

一旦安装了所有先决条件,您就可以构建HIPpo。首先将HIPpo GitHub存储库克隆到WSL系统的本地目录中。安装后,您可以构建和运行该应用程序,通过添加BINDLE_URL环境变量将其指向您的本地Bindle服务器。此时最好安装HIPpo的CLI,因为它是应用程序开发和部署所必需的。

您现在可以连接到您的HIPpo服务器以测试它是否正常工作。您应该在localhost的5001端口上找到它。如果您正在运行WSL 2的最新版本,您应该能够使用localhost从Windows桌面浏览器连接到它,因为Microsoft终于修复了WSL 2的一个长期存在的问题网络问题,通过Windows代理其虚拟机网络,同时仍保留其自己的IP地址和虚拟网络交换机。不再需要脚本来提取和共享网络地址。

在连接到服务器之前,您需要注册一个帐户。由于它在本地运行,您可以选择您喜欢的任何帐户详细信息;只要确保它们是您能记住的东西,因为您需要详细信息来构建您的第一个应用程序。创建帐户后,登录。您将被带到带有“创建新应用程序”按钮的“您的应用程序”页面。

创建您的第一个HIPpo WebAssembly应用程序

虽然您可以从Web UI为HIPpo构建应用程序,但现在使用命令行更容易。确保您已安装HIPpo CLI,因为Yeoman将使用它为您构建应用程序脚手架。在开始之前,为您的HIPpo帐户和密码及其端点设置环境变量。是的,这不是很好的安全实践,但在这里我们只是使用尚未准备好用于生产的软件在隔离的PC上构建和运行测试代码。

要构建一个基本的hello world应用程序,请使用yo-wasm工具构建一个WebAssembly RUst应用程序。如果您按照脚本操作并输入适当的值,这将构建源代码并将其加载到您的HIPpo服务器中。接下来使用RUst货物工具来编译和测试您的WASI应用程序。在命令行上运行它后,您可以使用HIPpo的CLI工具将其推送到Bindle,在那里它将在HIPpo中可见。打开项目,选择您构建的开发环境,然后单击链接以运行您的代码。

河马有很多值得喜欢的地方。如果WebAssembly缺少一件事,它是一个有效的类似Heroku的游乐场,可以帮助您入门。HIPpo可能还不是那个游乐场,但它肯定是您现在可以将其用作您自己的开发工作流程的一部分,即使在其早期阶段也是如此。能够在开发PC上运行它是一个额外的优势,因为不需要依赖第三方系统。它的影响足够低,可以作为WSL 2环境的一部分运行,因此您可以利用Visual Studio Code等工具,使用其远程开发功能从Windows编辑WSL中的RUst代码。

如果您对WebAssembly感兴趣,HIPpo很可能是您入门所需的工具。它使使用WebAssembly代码变得更简单,将运行开发所需的许多不同部分集中到一个地方。尽管它显然仍然是一个早期版本,但这里有足够的内容让您入门,使其成为任何使用WebAssembly的人的必备工具。

OpenMagic API

Need more than content? Move into the product flow.

If you are here for model access, pricing, developer docs, or the future API console, the dedicated product path now lives on api.openmagic.ai.

登录免费注册