Cloud Native Wasm DayからWebAssemblyのスケジューラーWADMを解説するセッションを紹介

2024年1月31日(水)
松下 康之 - Yasuyuki Matsushita
Cloud Native Wasm DayからCosmonicのエンジニアが解説する新しいスケジューラー、WADMのセッションを紹介する。

2023年11月6日に開催されたCloud Native Wasm Dayから、wasmCloudを開発するCosmonicのエンジニアが担当したセッションを紹介する。これはwasmCloudで利用されている新しいスケジューラーのWADM(WebAssembly Deployment Manager)についてデモを交えて解説したものだ。タイトルは「Orchestrating Wasm: Reconciliation Loops Aren't Owned by Kubernetes」で、セッションを行ったのはCosmonicのエンジニアリングディレクターのTaylor Thomas氏とインフラストラクチャーリードのDan Norris氏だ。

●セッションの動画:Orchestrating Wasm: Reconciliation Loops Aren't Owned by Kubernetes

プレゼンテーションを行うNorris氏(左)とThomas氏(右)

プレゼンテーションを行うNorris氏(左)とThomas氏(右)

最初にこのセッションの中身を紹介し、まずCosmonicが開発するwasmCloudを紹介、そのうえでどうしてwasmCloudのために新しいスケジューラーが必要になったのかという背景を解説したのち、動作を解説しデモで実際に動かしてみせるという内容だ。

セッションの概要を解説。途中でデモを挟んだ内容満載のセッションとなった

セッションの概要を解説。途中でデモを挟んだ内容満載のセッションとなった

wasmCloudはCosmonicが開発しオープンソースソフトウェアとして公開しているソフトウェアで、Cloud Native Computing Foundation(CNCF)のサンドボックスプロジェクトとして2021年7月13日に採用されている。

「wasmCloudが何に適しているのか?」を解説

「wasmCloudが何に適しているのか?」を解説

ここではwasmCloudがどんなコンピューティングシステムに適しているのか、また適していない使われ方は何か、などを解説している。データが複数の場所に分散し、プロセッサもデータセンターからエッジまでヘテロジニアスな形態で行われるような場合に最適であると解説している。特に後半のデモでも示されているように、ノートPCで実行したものをそのままオンプレミスのサーバーやパブリッククラウドで実行するなどの開発スタイルが可能になっていることから、単一のクラスターで完結するようなシンプルな構成では不足するようなユースケースを想定しているようだ。

またサーバーレスのような小さなプロセスが起動~終了を繰り返すような使われ方にも適していないと説明し、FermyonがWebAssemblyをサーバーレスで実行することを強力にプッシュするSpinとは違うポジショニングをしているように思える。

wasmCloudの特徴を再度確認

wasmCloudの特徴を再度確認

ここでは前のスライドの向き不向きを踏まえた上で、分散されたアプリケーションをどのプロセッサでもシームレスに実行できることをwasmCloudの最大の特徴として説明した。これはこの後に説明されるwasmCloudのスケジューラーWADMのための問い掛けと言えるだろう。ここまでの説明は、分散されたアプリケーションを実行するためのプラットフォームであるKubernetesを使わないのはなぜだろう? という疑問を参加者に持たせるための誘い水といえる。

「どうしてKubernetesでもNomadでもないのか?」を説明

「どうしてKubernetesでもNomadでもないのか?」を説明

そしてその答え合わせとして「どうしてKubernetesでもHashiCorpが開発し公開しているNomadでもないのか?」を説明。Kubernetesはすべてがコンテナであることが前提で、ManifestとCRD(Custom Resource Definition)という2つの構成情報が必須でシステムを複雑化させていること、そしてクラスターを超えて複数のクラウドや遠隔地のリージョンに存在するリソースをオーケストレーションすることが難しいと説明した。

もう一方のNomadについては、Kubernetesよりも自由度が高いがWebAssemblyのコンポーネントモデルのオーケストレーションを行うためには改造が必要となること、Nomadに慣れたデベロッパー、オペレーターが少ないこと、そしてKubernetesと同様にリージョンを超えたリソースのオーケストレーションができないことを挙げた。

WADMを作るための要件を整理

WADMを作るための要件を整理

ここで新しくスケジューラーを作るとしたら、何ができなければいけないかを整理し、コンテナではなくWebAssemblyのアプリケーションに特化し、単一のアプリケーション、サーバーレスのファンクションではなく複数のアプリケーションが連携するような使われ方が可能で、ManifestやCRDのように複数の定義情報が不要でシンプルに構成を定義できるシステムであるとする。そしてwasmCloudはそのように開発されたことを説明し、その中核にスケジューラーが必要であると語った。

スケジューラーの要件を整理

スケジューラーの要件を整理

このスライドではそのようなスケジューラーの開発において避けるべきことと、やらなければならないことを整理しており、Kubernetesのように連動すること、複雑な依存関係を避けること、分散処理に向いているがオフラインでも実行可能なこと(スタンドアロンのPCでも実行可能であること)、単一のバイナリーで構成されること、wasmCloudのAPIを使うことなどを挙げている。

WADMがNATSと連携して状態監視とリコンサイルループを実装

WADMがNATSと連携して状態監視とリコンサイルループを実装

このスライドではWADMがコントロールプレーンとしてユーザーからの指示を元にアプリケーション状態を監視し、アプリケーションを実行するというリコンサイルループを実装していることが示されている。Kubernetesとの違いはKubernetesがgRPCを使ってクラスター内のメッセージ交換を行い、ユーザーのアプリケーションにおいてはHTTPやWebSocketも選択可能な仕様になっていることとは異なり、NATSというCloud Foundry由来のメッセージ交換ソフトウェアに限定していることだろう。これによってクラスターを超えてエッジまでカバーする分散ネットワーク処理が可能になっている。

WADMがwasmCloudの状態を監視し、ユーザーが必要な状態に戻そうとする仕組み

WADMがwasmCloudの状態を監視し、ユーザーが必要な状態に戻そうとする仕組み

wasmCloudの中で実行されるアプリケーションはActorと称されているが、現在の状態と定義された状態を比較して定義通りの状態に保つのがスケジューラーであるWADMの仕事だ。

Rinse&Repeatと書かれているのがKubernetesで言うところのリコンサイルループ

Rinse&Repeatと書かれているのがKubernetesで言うところのリコンサイルループ

そしてそのメッセージ交換とリトライなどのエラー処理を一手に引き受けるのがJetStreamというNATSサーバーに組み込まれたストリーミング機能であると説明。ここでは深い説明を省いているが、wasmCloudの高機能なネットワークはwasmCloudではLatticeと命名されているNATSによるところが大きい。

NATSのJetStreamによって可能になっているwasmCloudのネットワーク機能

NATSのJetStreamによって可能になっているwasmCloudのネットワーク機能

ここでも挙げられているが、YAMLによるManifestだけで設定情報が完結していることがシステムをシンプルにしている要因であることを強調した。

ここからは実際にデモとして手元のノートPCとオンプレミスのサーバー、AzureやGCPのサーバーインスタンスなどを連携させて見せた。WebAssemblyのデモアプリケーションがどのインスタンスでも実行可能かつ即座に接続可能であるというwasmCloudの良さを見せつけるフェーズとなった。

wasmCloudのデモを実施

wasmCloudのデモを実施

ちなみにこの解説に使われているデモについては深く解説を省いているが、リクエストに対してランダムにイラスト画像を返すという内容のモノで、2023年9月に公開した以下の記事でも紹介しているので参照して欲しい。

●参考:wasmCloudのCosmonicのCEOが新しいデモを紹介

最後に今後の開発予定を紹介。アプリケーションを実行する際に登場するScalerという仕組みについて、ユーザーがカスタマイズすることをプラグインの形で可能にする計画があること、WADMの一部をWebAssemblyに置き換える構想があることなどを説明してセッションを終えた。

どのプラットフォームでも実行可能でサイズが小さいWebAssemblyの利点を最大限に活かしつつ、Kubernetesのようなリコンサイルループを採用してステートレスでマルチリージョンに分散したアプリケーションを実行可能なwasmCloudの中核となるスケジューラーを解説したセッションであった。wasmCloudがサーバーレスでも生成型AIの専用プラットフォームでもなく、これまでPaaSが使われていたような広範囲なユースケースを獲得したいと思うCosmonicの意志が表れていたセッションとなった。

著者
松下 康之 - Yasuyuki Matsushita
フリーランスライター&マーケティングスペシャリスト。DEC、マイクロソフト、アドビ、レノボなどでのマーケティング、ビジネス誌の編集委員などを経てICT関連のトピックを追うライターに。オープンソースとセキュリティが最近の興味の中心。

連載バックナンバー

クラウドイベント
第5回

KubeCon+CloudNativeCon North America 2023のキーノートとショーケースを紹介

2024/2/16
パンデミック後、最大のOSS系カンファレンスとなったKubeCon+CloudNativeCon North America 2023のキーノートと会場のようすを駆け足で紹介する。
クラウドイベント
第4回

Cloud Native Wasm Dayから大規模言語モデルをWasmで実行するデモを解説するセッションを紹介

2024/2/8
Second StateのMichael Yuan氏が解説する大規模言語モデルをWasmで実行するデモのセッションを紹介する。
クラウドイベント
第3回

Cloud Native Wasm DayからWebAssemblyのスケジューラーWADMを解説するセッションを紹介

2024/1/31
Cloud Native Wasm DayからCosmonicのエンジニアが解説する新しいスケジューラー、WADMのセッションを紹介する。

Think ITメルマガ会員登録受付中

Think ITでは、技術情報が詰まったメールマガジン「Think IT Weekly」の配信サービスを提供しています。メルマガ会員登録を済ませれば、メルマガだけでなく、さまざまな限定特典を入手できるようになります。

Think ITメルマガ会員のサービス内容を見る

他にもこの記事が読まれています