今回は、コンテナ技術の「Docker」について情報を整理していきます!
参考:
対象
- 未来の自分
- 以下の条件に当てはまる方
前提
- Dockerについて整理したい
- Docker初心者
本題
クライアントとサーバー
Web:クライアントであるWebブラウザと、そこにコンテンツを供給するWebサーバーで構成されるシステム。これはクライアント・サーバーシステムと呼ばれる。
-
クライアント:サーバーに対してリクエストを送信することで、サーバーが提供するコンテンツを利用するコンピューターやソフトウェアを指す。
-
サーバー:ユーザーからのリクエストに大路て、何らかのサービスを提供するコンピューターやソフトウェアのこと。
Webサーバーのほかに、データの保存や検索を行う「データベースサーバー」などがある。
コンテナ
コンテナとは、一言でいうと、**「アプリとファイルシステムを隔離する特殊なプロセス」**のこと。
プロセスとは、OS上で動作している1つ1つの処理のこと。
アプリとファイルシステムを隔離するということは、1つの物理マシンの中で動いているにもかかわらず、そのプロセスの中だけが別マシンで動いているような状態になるということ。
これが、従来の仮想化技術と異なるコンテナの仕組み。
コンテナ技術のデファクトスタンダードであるソフトウェアが「Docker」。
コンテナの仮想マシンとの違いは、ゲストOSを含まないこと。コンテナにインストールするのはLinux-OSのあくまで一部であり、OSのカーネル(OSの中核部分)はホストOSのものを使う。
コンテナはゲストOSがないから軽量。
また、仮想化技術には、仮想マシンだけでなく、ネットワークを仮想化した「ネットワーク仮想化」やストレージを仮想化した「ストレージ仮想化」などの種類がある。
Dockerでは、コンテナ間の通信や、コンテナの外部と通信する際に、この仮想ネットワークが使われる。
Dockerは、Linuxで動かすものであり、WindowsでDockerを使う場合は、Windows上で動作するLinuxが必要。
コンテナのメリットとデメリット
メリット
- 軽量である
コンテナは仮想マシンよりもはるかに軽量です。これは、ゲストOS全体をロードする代わりに、必要なアプリケーションとその依存関係のみを含んでいるためです。この軽量性により、起動時間が短縮され、システムリソースの消費が抑えられます。
- ホストOSを汚さずに環境構築できる
コンテナはホストOSから隔離されて動作します。これにより、アプリケーションが必要とする環境をホストOSに影響を与えることなく構築でき、互いに干渉しない環境を複数つくることができます。
- IaC(Infrastructure as Code)を実現する
コンテナ技術は、インフラストラクチャをコードとして管理することを可能にします。これにより、開発、テスト、本番環境間での環境の一貫性が保たれ、デプロイメントプロセスが自動化され、迅速化されます。また、Dockerではどんなコンテナをつくるか、といった手順をまとめたテキストファイルをもとにコンテナを創れるので、そのテキストファイルさえあれば、ほかの人が別のマシンでコンテナをつくることは容易です。
- 可搬性がある
コンテナはどのプラットフォーム上でも同じように動作するよう設計されています。これにより、開発環境からテスト、本番環境へとアプリケーションを簡単に移行することができます。
デメリット
- 学習コストが必要
コンテナ技術は多くの新しい概念を導入しており、特に従来の仮想化技術や物理サーバーから移行する場合、これらの技術を理解し適切に管理するためには時間と労力が必要です。
- 限定された可搬性
コンテナは一般的には可搬性が高いとされていますが、実際にはホストOSのカーネルを共有するため、異なるOS間での移行には制限があります。例えば、LinuxコンテナをWindowsや異なるLinuxディストリビューションでそのまま動かすことはできない場合があります。
コンテナイメージ
コンテナは、コンテナイメージ(以降、イメージ)からつくられる。イメージは、コンテナを作成するためのテンプレートのようなもの。イメージには、基本的なアプリやソフトウェアに加えて、コンテナを動かすのに必要なファイルシステムや、実行コマンド、メタ情報などが含まれている。コンテナに必要なファイルの集合体である。
コンテナhあ、あくまでプロセスなので、コンテナ自体を他の環境に配布することはできない。しかし、イメージはファイルの集合体なので配布が可能。つまり、イメージは、コンテナの可搬性を支える仕組みといえる。
コンテナのライフサイクル
コンテナは作っては削除が基本。
物理マシンに直接、アプリの事項環境を構築する場合、必要なソフトウェアを1つずつインストールすることが必要である。そして、その環境を削除する場合は、ソフトウェアを1つずつアンインストールしていく必要がある。対してコンテナは、作っては削除する、ことが簡単に出来る。