Cloudflare WorkersのJavaScript/WASMランタイム「workerd」がオープンソースで公開。NanoservicesやHomogeneous deploymentなど新技術を実装

今回は「Cloudflare WorkersのJavaScript/WASMランタイム「workerd」がオープンソースで公開。NanoservicesやHomogeneous deploymentなど新技術を実装」についてご紹介します。

関連ワード (ブラウザ、事実上、単一等) についても参考にしながら、ぜひ本記事について議論していってくださいね。

本記事は、Publickey様で掲載されている内容を参考にしておりますので、より詳しく内容を知りたい方は、ページ下の元記事リンクより参照ください。


Cloudflareは、同社のCDNエッジでJavaScript/WebAssemblyを実行するサービス「Cloudflare Workers」のコアランタイム部分を「workerd」(読み方はワーカーディー:worker- dee)としてオープンソースで公開しました。

GoogleがオープンソースのChromiumをベースにGoogle Chromeを製品として提供しているのと同様に、CloudflareはworkerdをベースにCloudflare Workersのソフトウェアを開発していると説明されています。

It’s here!

workerd (no that’s not a typo) the runtime that powers Cloudflare Workers is now open source under the Apache 2.0 license.
https://t.co/qoNOQdtkVW

— Cloudflare Developers (@CloudflareDev) September 27, 2022

workerdはローカルにおけるJavaScript/WebAssemblyランタイムとして、あるいはプログラマブルなHTTPプロキシなどとして利用可能です。

標準準拠でロックインはされない

workerdはサーバ向けのJavaScript/WebAssemblyのランタイムですが、基本的にはWebブラウザが備えているAPIを実装しています。

と同時にDenoやNode.jsなどと共に今年立ち上げた非Webブラウザ系JavaScriptランタイムのコード互換を実現するワークグループの標準に従うとしており、コードのworkerdへのロックインは起こらないとしています。

参考:Deno、Node.js、Cloudflare Workersなど、非Webブラウザ系JavaScriptランタイムのコード互換を目指す「Web-interoperable Runtimes Community Group」(WinterCG)が発足

Nanoservicesによる高速なマイクロサービスの実現

wokerdには2つの大きな実装上の特徴があります。1つ目がNanoservicesです。

Nanoservicesは、マイクロサービスアーキテクチャのためのより優れた実行環境を提供しようとする技術的な試みです。

一般にマイクロサービスアーキテクチャでは、それぞれがDockerコンテナで分離されたサービスをネットワークで接続することで相互に連携します。この場合、ネットワーク上でトラフィックのやりとりが発生し、そこでオーバーヘッドが生じるという課題があります。

workerdでは1つのプロセスの中を多数のそれぞれ独立したグローバルスコープを持つ「Isolate」と呼ばれる空間に分離します。そして各Isolateごとに個別のサービスに当たるWorkerを実行します。

Isolateは分離されつつも同一のプロセス内で動いているため、まるで関数呼び出しのように事実上ゼロレイテンシで非常に高速に相互のやりとりが可能になるわけです。

ただしIsolateにはサンドボックスのような高度な分離機能は持たせていないため、高度な分離が必要な場合には仮想マシンなど別の技術を用いる必要があるとも説明されています。

Homogeneous deploymentによるシンプルなデプロイとスケーリング

Dockerコンテナよりも軽量なIsolateを踏まえ、さらにマイクロサービスの課題を解決しようとworkerdでCloudflareが提唱するのが、2つ目の特徴である「Homogeneous depolyment」です。あえて訳すとすれば「同一性デプロイ」でしょうか。

マイクロサービスで構成されるアプリケーションを、例えば3台のサーバからなるクラスタにデプロイする場合には、サーバAにデプロイするサービス群、サーバBにデプロイするサービス群、サーバCにデプロイするサービス群などを設定し、それぞれにデプロイしていくことになるでしょう。

そしてサービスごとの負荷に応じてサービスのコンテナを増やしたり減らしたりしてスケールすることになります。

Homogeneous deploymentでは、こうしたサーバごとに異なるサービスのデプロイを不要にします。全てのサービスをクラスタを構成する全てのサーバにデプロイするのです。つまり、クラスタ内の全てのサーバは同一の構成になるわけです。

なぜこうするのか、これにどんなメリットがあるのについて、Cloudflareのブログ「Introducing workerd: the Open Source Workers runtime」から、Homogeneous deploymentの説明を引用しましょう。

workerd’s nanoservices are much lighter-weight than typical containers. As a result, it’s entirely reasonable to run a very large number of them – hundreds, maybe thousands – on a single server. This in turn means that you can simply deploy every service to every machine in your fleet.

workerdのNanoserviceは、一般的なコンテナよりもはるかに軽量です。そのため、1台のサーバで数百から数千といった非常に多くのサービスを実行することがまったく合理的になるのです。これはつまり、あなたのクラスタを構成するすべてのマシンに、単純にすべてのサービスをデプロイできることを意味します。

Homogeneous deployment means that you don’t have to worry about scaling individual services. Instead, you can simply load balance requests across the entire cluster, and scale the cluster as needed. Overall, this can greatly reduce the amount of administration work needed.

Homogeneous deploymentでは、個々のサービスのスケーリングを心配する必要がありません。その代わり、クラスタ全体でリクエストをロードバランスし、必要に応じてクラスタ自体をスケーリングすればよいのです。全体として、必要な管理作業の量を大幅に削減することができます。

要約すると、クラスタを構成するすべてのサーバは同一の構成だからデプロイが簡単で、その単純な同一構成のサーバを増やしたり減らしたりすればスケーラブルになるので、スケーリング作業もシンプルになる、ということです(実際の運用ではサーバは仮想マシンになり、Nanoservicesの数に合わせた仮想マシンの適切なサイジングなども必要なように思われます)。

これは、グローバルに分散したCDNによる負荷分散を提供しているCloudflareから出てきた発想として非常にうなずけます。

例えばあるアプリケーションにリクエストが集中していたとしても、そのリクエストの多くが東京と大阪からであれば、東京と大阪のそれぞれのエッジにリクエストは分散されるわけです。それぞれのエッジで同一構成でデプロイされたサーバがあれば、それで負荷は分散されるし、デプロイもシンプルになるわけです(アプリが単一のデータベースに依存している場合はその手当も必要になるとは思いますが)。

NanoserviceやHomogeneous deploymentは非常にユニークな提案に見えます。今後これがマイクロサービスにどのような影響を与えていくのか、そしてV8やWebAssemblyが持つ分離機能の実装などにもどのような影響を与えていくのかなど、注目していきたいと思います。

COMMENTS


Recommended

TITLE
CATEGORY
DATE
Intelが3.3兆円でチップメーカーGlobalFoundries買収を交渉中との噂
ハードウェア
2021-07-18 01:12
行かない役所・書かない役所を実現、xIDとトラストバンク提供のマイナンバーカード利用電子申請サービスを25自治体が導入
GovTech
2021-07-27 17:26
虹色に輝くG-SHOCK登場 モチーフは「鳳凰」
くらテク
2021-03-02 20:46
仮想空間に“もう一つの東京”? 東京都が「デジタルツイン」の3Dマップを作成、GitHubでソースコードも公開
DX
2021-08-03 09:58
イオン銀行に不正アクセス、個人情報2062件が流出 情報管理用クラウドツールで設定ミス
クラウドユーザー
2021-02-23 19:29
Amazon Prime Day 2023を支えたAWS。GravitonプロセッサのAmazon EC2インスタンス投入で消費エネルギーが昨年比60%減に
AWS
2023-08-07 11:26
ビッグデータ/AI活用におけるビジネス視点とコンテナー基盤
IT関連
2021-05-12 15:42
日本~シンガポールなどを結ぶ海底ケーブル、Facebookとグーグルが敷設へ
IT関連
2021-08-17 07:57
ライフログアプリSilentLogを提供するレイ・フロンティアが個人ユーザー・自治体・企業に向け防災機能をリリース
IT関連
2022-03-12 20:09
AWSとRKKCS、政府基準の自治体基幹システムパッケージの展開などで協業
IT関連
2022-07-06 06:55
日本オラクル社長が「基幹システムのレジリエンス向上」を強調した理由とは
IT関連
2024-02-10 10:33
Pepper生産中止・肉の包装・ベリーの収穫、多数の資金調達が行われた今週のロボティクスまとめ
ロボティクス
2021-07-04 10:54
NTTマーケティングアクトProCX、新パーパス策定–オペレーターの真価伝える
IT関連
2022-07-03 19:07
WebAssemblyでマルチスレッドによる並列処理を可能にする「wasi-threads」仕様の提案、ByteCode Allianceが明らかに
WebAssembly
2023-02-27 04:03