WebAssemblyとRustが作るサーバーレスの未来
RustとWebAssembly
そして次のパートとしてRustとWebAssemblyに関して説明を行い、Mozillaの中ではRustとWebAssemblyのワーキンググループができていることを紹介した。そもそもCやC++といったLow Level Languageにおいて、いかにメモリー関連の安全性を高めるか? というゴールに向かって開発されたRustが、CやC++とともに1st class citizenとして扱われているのは当然のことだ。そして、冒頭で紹介した「WebAssembly on the server is the future of computing」につながる接点が、やっと見えてきたというのが次のトピックだ。
サーバーレス
ここからが、このセッションのタイトルであるサーバーレスにつながる重要なポイントであろう。Webブラウザーの上でさまざまな言語のプログラムが稼働することを目指したWebAssemblyは、必ずしもブラウザーだけで実行されるわけではない。そのためにwasmtimeというランタイムが存在する。これはブラウザーを介さなくてもWebAssemblyのバイナリーが実行されることで、さまざまなプログラミング言語で書かれたプログラムがx86サーバーやARMのプロセッサーが搭載されたIoTデバイスでも実行が可能になるという話につながる。
その説明として、クラウドがどのように進化してきたのかをスライドを使って説明した。ここではデータセンターからIaaS、PaaSそしてサーバーレスに進化した際に、APIに注目していることがポイントだ。
つまり自社のデータセンターで稼働する場合は、LinuxなどのOSのAPIを使ってファイルやネットワークなどを使ってアプリケーションが実行される、一方PaaSの場合は、OSではなくそのプラットフォームのAPIとなり、より抽象化が進んだことになる。ここでは、APIが徐々に上のアプリケーションに近いレイヤーに上がってきていることに注意して欲しい。
そしてサーバーレスになった場合には、もはやOSやアプリケーションという外形ではなく、関数や機能という小さなレベルのプロセスがその下のAPIを通じてインフラストラクチャーを利用する形になる。これがAPIに注目した場合のアプリケーションの進化だ。この見方は、少し前であればDockerによるコンテナ化、そして2020年初頭の時点であればKubernetesによる複数のプロセスをAPIから制御する形に相応している。
この図をよく見ると、先にKlabnik氏が使ったWebAssemblyの図と相似であることが分かる。
つまりDockerがプログラミング言語の違いをコンテナでラップしていることに対し、バイナリーに変換されたRustなどのコードがランタイムを使ってサーバーサイドで実行されることでポータビリティーを獲得することになる。これによって、冒頭で紹介したSolomon Hykes氏の「2008年にWebAssemblyとWASIがあればDockerは必要なかった」という論点が整理されたのではないだろうか。コンテナはLinuxやWindowsなどのOSを区別する必要があるが、WebAssemblyであればその必要はないというわけだ。
WebAssembly System Interface(WASI)
ちなみにWebAssembly System Interface(WASI)とは、ブラウザーレスで実行する際にブラウザーがOSのAPIなどにアクセスしていた部分とのインターフェイスを定義するものだ。WASIはモジュール構造をとっており、WASI-Coreと呼ばれるモジュールがファイルシステムやネットワークなどへのアクセスを受け持ち、その他の追加機能は別モジュールで実装するという形式をとっている。
前のスライドで「グローバルなネットワークを作ることは巨大なサーバーファームを作ることではない」ということを強調したのは、AWSなどの巨大なサーバーファームがなくてもCloudflareの拠点にこのWebAssemblyのサーバー型アプリケーションを実装すれば、グローバルな展開は可能であるということを伝えたかったという意図がある。ちなみにCloudflareのPoP(Point of Presence)は、AWSのリージョン数よりもはるかに多いというのが次のスライドだ。
充実するWebAssemblyの周辺環境
そしてブラウザーレスでWebAssemblyのバイナリーを実行するランタイムも、Mozillaが公開しているwasmtimeの他に、Fastlyが開発し、Bytecode Allianceに寄贈されたLucetが存在する。
ちなみにBytecode AllianceはWebAssemblyとWASIをガバナンスするための団体であり、Mozilla、Fastly、Intel、Red Hatなどが参加している。他にもKlabnik氏が所属するCloudflareは、世界中に展開するCloudflareのサーバーにWebAssemblyのアプリケーションを実装するためのツールWorkerや、CLIツールWranglerなどを公開している。
最後にまとめとして、RustとWebAssemblyの親和性、WebAssemblyがサーバーレスのプラットフォームになる可能性、さらにARMなどのプロセッサーを使ったエッジでの可能性などを語ってセッションを終えた。
このセッションは、後半のブラウザーを使わずにランタイムを使ってサーバーレスを構築可能であるという部分がかなり駆け足となってしまったのが残念だが、JavaScriptを補完する形でブラウザーでのコンピューティングを拡張したWebAssemblyが、開発環境とCI/CDのためのツールやエンタープライズが求めるセキュリティなどの部分を充実させることで、サーバーレスに向かうというのは可能性としてはありえると思う。
今後は「マイクロサービスなどのユースケースに向けてエコシステムが拡大できるか?」「wasmコンテナの可能性は?」「Rustのランタイムとして市場をリードできるか?」「モニタリングやトレーシングなどのニーズに対応できるか?」という部分に注目が集まるだろう。Rustはデベロッパーからの注目を集めていることもあり、今後の動きに期待したい。
なお、動画は以下から視聴することができる。
動画:Rust, WebAssembly, and the future of Serverless
なおWebAssemblyをブラウザー以外で使うという部分に関しては、以下の動画も参考になる。これは2019年11月にコペンハーゲンで行われたGOTOというカンファンレスで行われたセッションである。セッションを行ったのはMozillaのDan Callahan氏だ。
連載バックナンバー
Think ITメルマガ会員登録受付中
全文検索エンジンによるおすすめ記事
- Rustで書かれたKubernetesのためのWASM実行環境Krustletとは?
- WebAssemblyを取り巻く最新情報をMeetupから紹介(後半)
- KubeCon EU 2021からセキュアでコンパクトなバイナリーフォーマットWASMのセッションを紹介
- WebAssemblyを取り巻く最新情報をMeetupから紹介(前半)
- 「KubeCon NA 2022」のプレカンファレンスからCloudNative Wasm DAYを紹介
- WASMを実行するためのランタイム、wasmCloudがCNCFのサンドボックスに
- KubeCon NA 2021開催。プレカンファレンスのWASM Dayの前半を紹介
- EnvoyをベースにしたAPI GatewayのGlooが最新バージョン1.3をリリース
- MozillaのWebAssemblyとは何か?: よりパワフルなWebアプリ
- 「KubeCon NA 2022」から、WasmEdgeを開発するSecond StateのMichael Yuanのインタビュー