まず仮想化とは?
ホストとなる1台のコンピュータの上に、仮想的に複数のコンピュータ(ゲストマシン)を構築する技術です。
個々のゲストマシンに独立してインストールしたOSを、ホストコンピュータのCPUでへ並行して動かすことができます。
上の図でいうと、GuestOS がプロセスを動しているということになります。
なお、ホスト型仮想化とハイパーバイザ型仮想化がある。
ホスト型仮想化は、ホストOS上で動作する仮想化ソフトウェアを利用してVMを管理する方式。
代表例:VirtualBox、VMWare
ハイパーバイザ型仮想化は、ハードウェア上のハイパーバイザを利用してVMを管理する方式。
代表例:KVM、Heper-V、Xen
一方、コンテナとは?
ホストとなる1台のコンピュータにインストールされているOSの上に、仮想的なユーザー空間であるコンテナを構築することができる。
上の図でいうと、Docker がプロセスを動かしているイメージです。
なので、利用する目的としては同じです!
仮想化の場合
・ゲストマシンごとにOSをインストールしなければいけない。
・物理的に複数のコンピュータを動かしていることになるため、ゲストマシンの数だけリソースが要求される。
・したがって、ホストコンピュータに対して、メモリやストレージなどのハードウェア環境にそれなりのコストをかけなければいけない。
・個々のゲストマシンの起動にも時間がかかる。
コンテナの場合
・OSをインストールする必要がないため、メモリなど大量に消費することがない。
・OS自体を共有しているため、それぞれの環境の起動も仮想化と比べて迅速に行うことができる。
・Dockerエンジンさえあれば基本どこでも動くため、可搬性が高い。
しかし、コンテナにはデメリットもある。。。
・1台のコンピュータで異なる複数のOSを使い分けることができない。
・コンテナが攻撃を受けると、ほかのコンテナにも危険にさらされる。
参考:Dockerのすべてが5分でわかるまとめ!(コマンド一覧付き)
モノリス
一枚岩のアーキテクチャでは、複数の機能を1つのアプリケーションの実行物として構築します。これまでの多くのアプリケーションはこの形で構築されています。例えば、サーバーサイドのWebアプリケーションの実装は、ビジネスロジック、UI、データベースアクセスなどが一体となった実行物としてビルド・配備されます。
これまではこのような一枚岩のアーキテクチャでも問題はなかったのですが、非常に大規模で複雑になるWebサービスを提供する上では、いくつか問題が目立つようになりました。
具体的には、
・ビジネス変化への素早い対応に向け、非常に高い変更頻度が求められる → ちょっとした変更でも、全体のリビルドと再配備に時間を必要とするため、変更が容易ではない。
・クライアント数の爆発などの変化に即応する高性能・高可用性が求められる → アプリケーションの一部の機能をスケールさせることが必要だったとしても全体を複製しなければいけないため、スケーリングに柔軟性がない。
マイクロサービス
マイクロサービスはこれらの問題を解決し、アプリケーションを構成する個々のサービスは独立したプロセスで実行されるように配備します。
それにより、
・きめ細かにスケールできるようになる。
・変更の影響範囲を限りなく小さくすることができる。
マイクロサービスのデメリットとして、分散化するシステム設計が複雑になる、通信オーバヘッドが大きくなる、運用管理が大変である、といったものがあります。
だから、マイクロサービスはコンテナと相性がいい!
新しい機能をどんどん追加して試していきたい。
ダメだったらすぐに切り捨てていきたい。
変化の激しいユーザのニーズに対応したい。
マイクロサービスなら、アプリケーションごとに捨てることができるので、注目されている。
#■AWSのコンテナ関連サービス#
分類 | 説明 |
---|---|
レジストリ | 各サーバが実行するコンテナイメージを一元管理する。 各サーバに配布するのではなく、必要な時にサーバが取りにいくことで配布する手間がなくなります。 |
コントロールプレーン | コンテナの管理する場所。 (どこでコンテナを動かす?デプロイ時にどう配置する?) |
データプレーン | 実際にコンテナが稼働する場所。 (コントロールプレーンからの指示に従って起動する。そして、コントロールプレーンへ逆にフィードバックする。 |
では、それぞれのサービスについて具体的に見てみましょう。
■Amazon Elastic Container Service (ECS)
Amazon ECS に書きました。
■Amazon Elastic Container Service (EKS)
Amazon EKS に書きました。
■AWS Fargate
AWS Fargate に書きました。