マイクロサービス (英語 :microservices )とは、ソフトウェア開発 の技法の1つであり、1つのアプリケーション を、ビジネス機能に沿った複数の小さいサービス の疎に結合された 集合体として構成するサービス指向アーキテクチャ (service-oriented architecture; SOA)の1種である。マイクロサービスアーキテクチャでは、各サービスはきめ細かい粒度 (英語版 ) を持ち、軽量なプロトコル を用いて通信を行う。
アプリケーションを異なる小さなサービスに分割することの利点は、モジュラリティ (英語版 ) が高くなることである。これによって、アプリケーションの理解、開発、テストがより簡単に行えるようになり、アーキテクチャの腐敗に対する弾力性が向上する[ 1] 。マイクロサービスによる開発を行うことで、開発 が並列化され、少人数の自律的なチームにより、各チームが所有するサービスを独立に、開発、デプロイ 、スケールさせることが可能になる[ 2] 。また、継続的リファクタリング を通して、個々のサービスのアーキテクチャ全体を置き換えることも可能になる[ 3] 。マイクロサービスベースのアーキテクチャでは、継続的デリバリー と継続的デプロイ が可能になる[ 4] 。
2014年、ThoughtWorks社のマーチン・ファウラーとジェームス・ルイスが提唱したソフトウェアアーキテクチャである[ 5] 。
何がマイクロサービスであるか、という公式な定義は存在しないが、業界では徐々にコンセンサスが形成されつつある。マイクロサービスを特徴づける定義としてよく引き合いに出されるものとしては、以下のような点が挙げられる。
マーティン・ファウラー や他の専門家たちによれば、マイクロサービス・アーキテクチャ(microservice architecture; MSA)は、特定の技術にとらわれないHTTPなどのプロトコル を使用して、目的を達成するためにネットワーク 越しのコミュニケーションのプロセス を実行する[ 6] [ 7] [ 8] 。ただし、サービスは共有メモリ などの他の種類のプロセス間通信 のメカニズムを使用することもある[ 9] 。また、たとえばOSGI バンドルなどのように、同一のプロセス内で実行される場合もある。
マイクロサービス・アーキテクチャにおけるサービスは、独立にデプロイが可能である[ 10] [ 11] 。
サービスは、きめ細かい粒度のビジネス機能を中心に組織される。マイクロサービスにおいて粒度は重要である。なぜなら、粒度こそ、このアプローチをSOA と異なるものにしているからである。
各サービスに最も適した異なるプログラミング言語 、データベース 、ハードウェアおよびソフトウェア環境で開発することができる[ 11] 。これは、1つのマイクロサービスがさまざまなプログラミング言語のパッチワークのように書かれるという意味ではない。
サービスはサイズが小さく、メッセージングを行い、コンテキストによって境界づけられ、自律的に開発される。また、中央集権的ではなく、独立してデプロイが可能である。そして、自動化されたプロセスにより、自動ビルド と自動リリース が実行される[ 10] 。
マイクロサービスは、モノリシックなアプリケーション内にある1つのレイヤー(たとえば、ウェブコントローラや、フロントエンド向けバックエンド(backend-for-frontend)[ 12] )ではない 。むしろ、自身のみでビジネス機能を提供する、明確なインターフェイスを持った小さなピースである(サービス内部のコンポーネントとしてレイヤーアーキテクチャを実装することさえある)。戦略的な観点からは、マイクロサービスは 「ただ1つのことをして、それをうまくやる」[ 13] というUnix哲学 に本質的には従っているものとして考えられる。マーティン・ファウラー は、マイクロサービス・アーキテクチャには次のような性質があると述べている[ 6] 。
なお、「マイクロサービス」という用語は、2011年5月にヴェネツィア近郊のソフトウェアアーキテクトのワークショップで議論され、参加者が最近調査した共通のアーキテクチャースタイルと見なした内容を提唱者らが説明している。2012年5月、同グループが最も適切な名前として「マイクロサービス」を決定した。
提唱者らは下記に述べる特性を挙げているがこれらは定義ではなく、すべての特性をもつ必要はないとしている[ 5] 。
サービスのコンポーネント化 - コンポーネントは独立して交換・更新可能なソフトウェアの単位である。
ビジネス中心組織 -開発運用チームは技術や開発工程によるチームではなく、ビジネスを中心に機能横断型のチームが編成されている。
プロジェクトではなくプロダクト - チームは開発完了とともに解散するプロジェクトモデルではなく、製品のライフサイクル全体に責任を持つ。
スマートエンドポイントとダムパイプ - メッセージ通信は軽量かつシンプルであること。エンドポイントに高い機能を持たせ、通信はダムパイプ(メッセージのルータとしてのみ動作する単純な機構)であること。
分散統治 - 各サービスは独立したチーム、開発言語、ツールでアプローチする。
分散データ管理 - 概念モデルに関する分散だけでなく、データストレージも分散(サービス間で独立)する。
インフラストラクチャの自動化 - テスト自動化/継続的デリバリー/継続的インテグレーションの導入
障害の設計 - 個々のサービスはいつでも失敗する可能性があるため、互いに障害を迅速に検出し、可能であれば自動的にサービスを復元できることが重要。
進化的な設計 - 頻繁に、迅速に、適切に制御されたソフトウェアの変更・廃止・構築を行うことができること。
従来のソフトウェアアーキテクチャは単一のアプリケーションとして構築されたモノリシックアーキテクチャが主流であった。しかし、ビジネスや環境の変化とともにアプリケーションへの変更サイクルが短くなり、特にモノリシックアーキテクチャの場合はアプリケーション全体を再構築して展開する必要がある。時間の経過とともに、適切なモジュール構造を維持することは難しいため、そのモジュール内の1つのモジュールにしか影響を与えない変更を維持するのが難しくなってしまう。
技術の発展とサービスの多様化に伴い、モジュールが独立して展開可能でなおかつスケーラブルであるようになる。
また、堅固なモジュール境界を提供し、それぞれの機能が異なるプログラミング言語で書かれることを可能にした。さらに、異なるチームによって開発・運用管理することもできるようになることで、一部の変更が全体へ影響を及ぼすことへのリスクがサービスの独立によって解消できるアプローチスタイルが出来上がった[ 5] 。
モノリシックアーキテクチャと比較し、下記の欠点を上げている。[ 5]
共通化基盤とコンポーネント境界をどこに定めるべきかが困難 - リリースや変更するサービス単位が境界になるがビジネスやマーケットに左右される。
インターフェース変更に伴うリファクタリング - サービス境界全体では変更が難しく、参加者間でインターフェイスの変更を調整する必要があり、かつ後方互換性のレイヤーを追加する必要があり、テストがより複雑になる。
複雑化されたコンポーネント - コンポーネントがきれいに構成されていない場合、コンポーネント内からコンポーネント間の接続へ複雑さがシフトしてしまいそれがさらに波及するリスクがある。
チームスキル - スキルが高いチームに効果的な技術は、スキルの低いチームでは必ずしも機能しない。この問題が一部のマイクロサービスに混入した場合、システム全体に影響する可能性がある。
2014年当初の提唱者らは「マイクロサービスがソフトウェアアーキテクチャの将来の方向性であると確信していると主張しているわけではない」と語る。
アプローチのひとつとしては、マイクロサービスアーキテクチャから始めるべきではないということ。代わりにモノリスで始め、モジュール化したままにし、モノリスが問題になったらマイクロサービスに移行・分割していく。
マイクロサービスを構成するネットワーク基盤をサービスメッシュと呼び、ネットワーク基盤をアプリケーションから隠蔽することでマイクロサービスをより容易に実現しようと試みられている。
サービスメッシュ (Service Mesh )は、アプリケーションを構成するマイクロサービス群からなるネットワークである[ 14] 。マイクロサービス間通信を用いてアプリケーションを構成するには、データ転送の制御と監視が必須である。要件の例としては以下が挙げられる[ 15] 。
さらにA/Bテストやカナリアデプロイ、レート制限、アクセス制御 、認証 、カオスエンジニアリングなど様々なネットワーク関連の要件が発生しうる[ 16] 。サービスメッシュに着目した場合、ネットワークに由来するこれらの困難さをアプリケーションから隠蔽するためにプロキシなどの様々な手法が用いられる。
ネットワークの転送部は転送を担うデータプレーン (data plane)と転送制御を決定するコントロールプレーン(control plane)に分離できる(c.f. Software Defined Networking )。アプリケーションからデータプレーンおよびコントロールプレーンを分離することでアプリケーションからサービスメッシュを隠蔽する手法が主流である。
例えばEnvoyはService Meshにおけるデータプレーンプロキシである[ 17] 。Envoyプロキシは各マイクロサービスに同梱され、Envoy間で通信を行うことでサービスメッシュを構成する。マイクロサービスは同梱されるEnvoyプロキシのみを見ているため、サービスAppにとってサービスメッシュは透過的に扱われる(隠蔽されている)。Eovoyデータプレーンが利用する制御情報は別に用意されたコントロールプレーンから提供される(例: humanコントロールプレーンによる静的設定ファイル、Istioによるコントロールプレーンサービス)。
クラウドコンピューティング によるマネージドコントロールプレーンも提供されている。例えばAmazon Web Services はAWS App MeshによりEnvoyをデータプレーンとしたマネージドコントロールプレーンを提供している[ 18] 。
^ Chen, Lianping (2018). Microservices: Architecting for Continuous Delivery and DevOps . The IEEE International Conference on Software Architecture (ICSA 2018) . IEEE.
^ Richardson. “Microservice architecture pattern ” (英語). microservices.io . 2017年3月19日 閲覧。
^ Chen, Lianping; Ali Babar, Muhammad (2014). Towards an Evidence-Based Understanding of Emergence of Architecture through Continuous Refactoring in Agile Software Development . The 11th Working IEEE/IFIP Conference on Software Architecture(WICSA 2014) . IEEE. doi :10.1109/WICSA.2014.45 。
^ Balalaie, Armin; Heydarnoori, Abbas; Jamshidi, Pooyan (2016-05). “Microservices Architecture Enables DevOps: Migration to a Cloud-Native Architecture”. IEEE Software 33 (3): 42–52. doi :10.1109/ms.2016.64 . ISSN 0740-7459 .
^ a b c d
James Lewis. “Microservices ”. martinfowler.com. 2018年12月6日 閲覧。
^ a b Martin Fowler. “Microservices ”. 14 February 2018時点のオリジナル よりアーカイブ。2018年1月2日 閲覧。
^ Newman, Sam (2015-02-20). Building Microservices . O'Reilly Media. ISBN 978-1491950357
^ Wolff, Eberhard (2016-10-12). Microservices: Flexible Software Architectures . ISBN 978-0134602417 . http://microservices-book.com
^ “Micro-services for performance ”. Vanilla Java (2016年3月22日). 2017年3月19日 閲覧。
^ a b Nadareishvili, I., Mitra, R., McLarty, M., Amundsen, M., Microservice Architecture: Aligning Principles, Practices, and Culture, O’Reilly 2016
^ a b Chen, Lianping (2018). Microservices: Architecting for Continuous Delivery and DevOps . The IEEE International Conference on Software Architecture (ICSA 2018) . IEEE.
^ “Backends For Frontends Pattern ”. Microsoft Azure Cloud Design Patterns . Microsoft. 2018年1月2日 閲覧。
^ Lucas Krause. Microservices: Patterns and Applications . ASIN B00VJ3NP4A
^ The term service mesh is used to describe the network of microservices that make up such applications and the interactions between them. Istio - Docs - What is Istio
^ Its requirements can include discovery, load balancing, failure recovery, metrics, and monitoring. Istio - Docs - What is Istio
^ A service mesh also often has more complex operational requirements, like A/B testing, canary rollouts, rate limiting, access control, and end-to-end authentication. Istio - Docs - What is Istio
^ Envoy is the data plane . Matt Klein (2017). "Service mesh data plane vs. control plane "
^ In the following diagram, a sidecar runs alongside each container in your application to provide its proxying logic, syncing each of their unique configurations from the App Mesh control plane. AWS Compute Blog (2019) "Learning AWS App Mesh "
S. Newman, Building Microservices – Designing Fine-Grained Systems, O'Reilly, 2015 ISBN 978-1491950357
I. Nadareishvili et al., Microservices Architecture – Aligning Principles, Practices and Culture , O’Reilly, 2016, ISBN 978-1-491-95979-4
SEI SATURN 2015 microservices workshop, https://github.com/michaelkeeling/SATURN2015-Microservices-Workshop
Wijesuriya, Viraj Brian (2016-08-29) Microservice Architecture, Lecture Notes - University of Colombo School of Computing, Sri Lanka