一个简单的 WASI 例子

在这篇文章中,我会向你展示如何去构建一个 WebAssemblely 应用的容器镜像。然后可以通过 Kubernetes 生态系统工具(例如 CRI-O、Docker、crun 和 Kubernetes)来启动和管理它。

先决条件

如果你只是想要一个 wasm 字节码文件作为容器镜像进行测试,你可以跳过构建步骤,只需在此处下载 wasm 文件

首先,请按照这些简单的说明来安装 Rust

下载样例代码

  1. git clone https://github.com/second-state/wasm-learning
  2. cd wasm-learning/cli/wasi

构建 WASM 字节码

  1. rustup target add wasm32-wasi
  2. cargo build --target wasm32-wasi --release

wasm 字节码应用程序位于 target/wasm32-wasi/release/wasi_example_main.wasm 文件中。你现在可以将其发布并用作容器镜像。

申请 Wasm 字节码的执行权限

  1. chmod +x target/wasm32-wasi/release/wasi_example_main.wasm

创建 Dockerfile

target/wasm32-wasi/release 文件夹中创建一个命名为 Dockerfile 的文件,其内容如下:

  1. FROM scratch
  2. ADD wasi_example_main.wasm /
  3. CMD ["/wasi_example_main.wasm"]

创建一个带注释的容器镜像

请注意,添加自定义注释仍然是 buildah 中的新功能。

crun 容器运行时可以启动上述基于 WebAssembly 的容器镜像。但它需要容器镜像上的 module.wasm.image/variant=compat 注释来表明它是一个没有客人操作系统(安装在虚拟机上的系统)的 WebAssembly 应用程序。你可以在官方 crun repo 中找到详细信息。

要在容器镜像中添加 module.wasm.image/variant=compat 注释,你需要最新的 buildah。 目前,Docker 不支持此功能。请按照 buildah 的安装说明 构建最新的 buildah 二进制文件。

在 Ubuntu 上编译并安装最新的 buildah

在 Ubuntu zesty 和 xenial 上,使用这些命令为 buildah 做准备。

  1. sudo apt-get -y install software-properties-common
  2. export OS="xUbuntu_20.04"
  3. sudo bash -c "echo \"deb https://download.opensuse.org/repositories/devel:/kubic:/libcontainers:/stable/$OS/ /\" > /etc/apt/sources.list.d/devel:kubic:libcontainers:stable.list"
  4. sudo bash -c "curl -L https://download.opensuse.org/repositories/devel:/kubic:/libcontainers:/stable/$OS/Release.key | apt-key add -"
  5. sudo add-apt-repository -y ppa:alexlarsson/flatpak
  6. sudo apt-get -y -qq update
  7. sudo apt-get -y install bats git libapparmor-dev libdevmapper-dev libglib2.0-dev libgpgme-dev libseccomp-dev libselinux1-dev skopeo-containers go-md2man containers-common
  8. sudo apt-get -y install golang-1.16 make

然后,按照下列步骤在 Ubuntu 上编译和安装 buildah。

  1. mkdir -p ~/buildah
  2. cd ~/buildah
  3. export GOPATH=`pwd`
  4. git clone https://github.com/containers/buildah ./src/github.com/containers/buildah
  5. cd ./src/github.com/containers/buildah
  6. PATH=/usr/lib/go-1.16/bin:$PATH make
  7. cp bin/buildah /usr/bin/buildah
  8. buildah --help

创建和发布具备 buildah 的容器镜像

target/wasm32-wasi/release/ 文件夹下,执行下列指令。

  1. $ sudo buildah build --annotation "module.wasm.image/variant=compat" -t wasm-wasi-example .
  2. # make sure docker is install and running
  3. # systemctl status docker
  4. # to make sure regular user can use docker
  5. # sudo usermod -aG docker $USER
  6. # newgrp docker
  7. # You may need to use docker login to create the `~/.docker/config.json` for auth.
  8. $ sudo buildah push --authfile ~/.docker/config.json wasm-wasi-example docker://docker.io/hydai/wasm-wasi-example:with-wasm-annotation

好了! 现在你可以尝试在 CRI-OKubernetes 上运行它了!