Google、モノリスとマイクロサービスのいいとこ取りをする「Service Weaver」フレームワークをオープンソースで公開

今回は「Google、モノリスとマイクロサービスのいいとこ取りをする「Service Weaver」フレームワークをオープンソースで公開」についてご紹介します。

関連ワード (今後、代表例、変更等) についても参考にしながら、ぜひ本記事について議論していってくださいね。

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


Googleは分散アプリケーションの開発とデプロイを容易にするフレームワーク「Service Weaver」をオープンソースで公開しました。

Introducing Service Weaver!

Service Weaver is an open source framework for building and deploying distributed applications. It allows you to write your application as a modular monolith and deploy as a set of microservices.

Learn more → https://t.co/XmnVALYXNC pic.twitter.com/N67AWTA9kn

— Google Open Source (@GoogleOSS) March 1, 2023

マイクロサービスとモノリシック、それぞれの利点

分散アプリケーションの代表例となっているマイクロサービスは、複数のサービスの連係によってアプリケーションを構成します。スケーラブルで可用性が高く、アプリケーションを構成するサービスごとにアップデートや機能追加などが容易なため、大規模なアプリケーションの開発に向いている、などの利点があります。

一方で、アプリケーションを構成する複数のサービスごとに発生する多数のバイナリの管理、ネットワーク上での相互接続のためのコンフィグレーションの作成、相互にデータ連係するためのデータフォーマットやシリアライゼーションの管理、そしてデプロイの手間の多さや複雑さなどによるデプロイの遅さなど、さまざまな課題があるとGoogleは指摘しています。

特に、複数のバイナリに渡る機能変更を管理することは難しく、いちど決めたデータフォーマットやAPIの改善も困難であるとされます。

マイクロサービスとは対照的に、シングルバイナリで構成されるモノリシックなアプリケーションにはこうした課題はほとんどなく、機能追加や変更は容易で、デプロイもバイナリを置くだけとスピーディです。

アップデートもソースコードを書き換えてビルドし、バイナリを置き換えるだけ、といったシンプルさです。

Googleがオープンソースとして公開したService Weaverはこの、モノリシックなアプリケーションのシンプルな開発体験で作られたアプリケーションを、デプロイ時にはマイクロサービスとして自動的に分散してデプロイしてくれるという、2つのいいとこ取りをすることを目指したフレームワークです。

モノリスとして作り、自動的にマイクロサービスとしてデプロイ

Service Weaverを用いたアプリケーション開発では、単なるモノリシックなアプリケーションではなく「Modular monolith」(モジュラーモノリス)なアーキテクチャスタイルでアプリケーションを開発します。

モジュラーモノリスとは、その内部を適切に分割したモジュール構造を備えているモノリシックなアプリケーションです。

これにより、モノリシックなアプリケーションの利点であるシンプルな開発や機能追加や変更、シンプルでスピーディなデプロイといった特性を備えつつ、後からモジュールごとに分割することが容易になります。

Service Weaverは、モジュラーモノリスなアプリケーションを開発するためのライブラリ を備えており、このライブラリを用いてアプリケーションを開発します。

さらにService Weaverはデプロイツールも備えています。

Service Weaverのライブラリを用いて開発されたモジュラーモノリスなアプリケーションは、例えばデスクトップPC上ではそのまま簡単に実行できます。

そして、Google CloudのKubernetesサービスであるGoogle Kubernetes Engineや、それ以外のクラウドに対しては、マイクロサービスアプリケーションとしてデプロイすることも可能なわけです。

fig

Service Weaverは現時点でまだバージョン0.1であり、Go言語のコアライブラリ、ローカルとGoogle Kubernetes Engineへデプロイし実行するためのツール、そしてデプロイツールのためのAPI群などが揃っている状態。今後、破壊的な変更を含む機能変更や追加などの可能性があるとのことです。

COMMENTS


Recommended

TITLE
CATEGORY
DATE
AWS上でOpenShiftのマネージドサービス提供、「Red Hat OpenShift Service on AWS」正式リリース
AWS
2021-03-29 22:20
気候変動緩和の可能性–期待される5つのテクノロジー
IT関連
2023-03-09 16:22
米下院司法委員会、GAFA規制の5法案を提出 企業分割や買収規制
企業・業界動向
2021-06-13 05:50
アークサーブ、ランサムウェア対策を施したバックアップストレージを発表
IT関連
2022-05-24 10:35
NECら13社、コンソーシアム設立に基本合意–海外拠点持つ企業への5Gソリューション提供へ
IT関連
2021-02-06 05:56
米アマゾン、Amazon Booksや4-star storeなど68の実店舗を閉鎖へ
IT関連
2022-03-04 17:27
DMMブックス、初回100冊7割引きクーポンで損失60億円 オウンドメディアで明らかに
くらテク
2021-07-02 05:15
料理人が飲食店の空き時間にオリジナルお弁当を販売できる「smallkitchens」が資金調達
フードテック
2021-01-27 20:54
ID管理の今後は消費者向けサービスが鍵に–OktaのケレストCOO
IT関連
2021-03-31 14:44
安全性重視の暗号資産ウォレットZenGoが約21.7億円調達、デビットカードも近く提供
ブロックチェーン
2021-04-29 13:45
エヴァ新劇場版の名せりふ、海外ではこうなる 11言語による名場面集をYouTubeで公開
くらテク
2021-08-13 19:05
イーサリアム互換ブロックチェーン構築クラウドなどを手がけるG.U.テクノロジーズがプレシリーズAで2.6億円の追加調達
IT関連
2022-03-09 05:25
競技プログラミング(競プロ)コンテストサイト「AtCoder」の世界登録ユーザー数が30万人を突破
EdTech
2021-07-29 05:18
読み取りが最大33%高速化したドキュメントスキャナー「ScanSnap iX1600 / iX1400」実力チェック
ハードウェア
2021-02-15 22:55