Windows とコンテナー

適用対象: Windows Server 2022、Windows Server 2019、Windows Server 2016

コンテナーは、オンプレミスおよびクラウドの多様な環境にわたって Windows と Linux のアプリケーションをパッケージ化して実行するためのテクノロジです。 コンテナーは、アプリの開発、デプロイ、管理を容易にする軽量で分離された環境を提供します。 コンテナーはすばやく開始および停止するので、需要の変化に迅速に対応する必要があるアプリに最適です。 また、軽量であるというコンテナーの性質により、インフラストラクチャの密度と使用率の向上に役立つツールでもあります。

Graphic showing how containers can run in the cloud or on-premises, supporting monolithic apps or microservices written in nearly any language.

計画済みおよび現在利用可能な機能のロードマップを表示するには、「Windows Server コンテナーのロードマップ」を参照してください。 また、「イベント」を参照して、Windows コンテナーに関する最新のビデオ プレゼンテーションやブログの投稿を確認してください。

Microsoft コンテナーのエコシステム

Microsoft では、コンテナーでのアプリの開発とデプロイに役立つ多数のツールとプラットフォームを提供しています。

  • Docker Desktop を使用した開発およびテストのために、Windows ベースまたは Linux ベースのコンテナーを Windows 10 で実行します。これにより、Windows に組み込まれているコンテナー機能を利用することができます。 また、Windows Server でネイティブにコンテナーを実行することもできます。

  • Docker、Docker Compose、Kubernetes、Helm、およびその他の便利なテクノロジのサポートを含む、Visual Studio での強力なコンテナー サポート および Visual Studio Code を使用して、Windows ベースのコンテナーを開発、テスト、発行、デプロイします。

  • Visual Studio と Visual Studio Code 内から直接プッシュおよびプルして、他のユーザーが使用できるようにパブリック DockerHub に、または組織の独自の開発とデプロイのためにプライベート Azure Container Registryアプリをコンテナー イメージとして発行します。

  • Azure (またはその他のクラウド) に大規模にコンテナーをデプロイします

    • Azure Container Registry などのコンテナー レジストリからアプリ (コンテナー イメージ) をプルし、Azure Kubernetes Service (AKS) などのオーケストレーターを使用して大規模にデプロイおよび管理します。
    • Azure Kubernetes Service は、コンテナーを Azure の仮想マシンにデプロイし、数十、数百、または数千個であってもそれらを大規模に管理します。 Azure の仮想マシンは、カスタマイズされた Windows Server イメージ (Windows ベースのアプリをデプロイしている場合)、またはカスタマイズされた Ubuntu Linux イメージ (Linux ベースのアプリをデプロイしている場合) のいずれかを実行します。
  • AKS on Azure Stack HCIAKS エンジンを使用した Azure Stack、または OpenShift を使用した Azure Stack を使って、コンテナーをオンプレミスにデプロイします。 また、Windows Server に自分で Kubernetes をセットアップすることもできます (「Windows で使用する Kubernetes」を参照)。さらに、Microsoft では、RedHat OpenShift Container Platform で Windows コンテナーを実行するためのサポートについても取り組んでいます。

コンテナーのしくみ

コンテナーは、ホスト オペレーティング システムでアプリケーションを実行するための、分離された軽量のパッケージです。 コンテナーは、以下の図に示すように、ホスト オペレーティング システムのカーネル (オペレーティング システムの埋め込まれた配管のようなものと見なすことができる) の上に構築されます。

Architectural diagram showing how containers run on top of the kernel

コンテナーはホスト オペレーティング システムのカーネルを共有しますが、コンテナーがそれに自由にアクセスすることはできません。 代わりに、コンテナーは、分離された (場合によっては、仮想化された) システムのビューを取得します。 たとえば、コンテナーは、ファイル システムとレジストリの仮想化されたバージョンにアクセスできますが、変更はコンテナーにのみ影響し、停止すると破棄されます。 データを保存するために、コンテナーは Azure Disk やファイル共有 (Azure Files など) の永続的ストレージをマウントできます。

コンテナーはカーネルの上に構築されますが、カーネルは、アプリが実行する必要のあるすべての API とサービスを提供するわけではありません。これらのほとんどは、ユーザー モードのカーネルの上で実行されるシステム ファイル (ライブラリ) によって提供されます。 コンテナーはホストのユーザー モード環境から分離されているため、コンテナーにはこれらのユーザー モード システム ファイルの独自のコピー (基本イメージと呼ばれるものにパッケージ化されている) が必要です。 基本イメージは、コンテナーが構築される基本層として機能し、カーネルによって提供されないオペレーティング システム サービスを提供します。 コンテナー イメージの詳細については後で説明します。

コンテナーと仮想マシン

コンテナーとは対照的に、仮想マシン (VM) は、次の図に示すように、独自のカーネルを含む完全なオペレーティング システムを実行します。

Architectural diagram showing how VMs run a complete operating system beside the host operating system

コンテナーと仮想マシンにはそれぞれの使用法があります。実際、コンテナーの多くのデプロイでは、仮想マシンをハードウェア上で直接実行するのではなく、ホスト オペレーティング システムとして使用します (特にクラウドでコンテナーを実行している場合)。

これらの補完的なテクノロジの類似点と相違点の詳細については、「コンテナーと仮想マシン」を参照してください。

コンテナー イメージ

すべてのコンテナーは、コンテナー イメージから作成されます。 コンテナー イメージは、ローカル コンピューターまたはリモート コンテナー レジストリに存在する多数の層に編成されたファイルのバンドルです。 コンテナー イメージは、アプリをサポートするために必要なユーザー モードのオペレーティング システム ファイル、アプリのランタイムまたは依存関係、アプリを正常に実行するために必要なその他の構成ファイルで構成されています。

Microsoft では、独自のコンテナー イメージを構築するための出発点として使用できるいくつかのイメージ (基本イメージと呼ばれる) を提供しています。

  • Windows - Windows API とシステム サービス (サーバー ロールは除く) の完全セットが含まれています。
  • Windows Server - Windows API とシステム サービスの完全セットが含まれています。
  • Windows Server Core - Windows Server API (つまり、完全な .NET framework) のサブセットを含む小さいイメージ。 また、ほとんどのサーバー ロールが含まれていますが、すべてが含まれているわけではありません (たとえば、Fax サーバーは含まれていません)。
  • Nano Server - 最小の Windows Server イメージ。 .NET Core API と一部のサーバー ロールのサポートが含まれています。

既に説明したように、コンテナー イメージは一連の層で構成されています。 各層には一連のファイルが含まれており、それが重なり合って、コンテナー イメージを表します。 コンテナーには複数層の性質があるため、Windows コンテナーを構築するために、常に基本イメージをターゲットにする必要はありません。 代わりに、必要なフレームワークを既に保持している別のイメージをターゲットにすることができます。 たとえば、.NET チームは、.NET Core ランタイムを保持する .NET Core イメージを発行します。 これにより、ユーザーは、.NET Core をインストールするプロセスを繰り返す必要がなくなり、代わりにこのコンテナー イメージの層を再利用することができます。 .NET Core イメージ自体は、Nano Server に基づいて構築されています。

詳細については、「コンテナーの基本イメージ」を参照してください。

コンテナーのユーザー

開発者向けのコンテナー

コンテナーを使用すると、開発者は、より品質の高いアプリをより短時間で作成して出荷することができます。 コンテナーにより、開発者は、数秒で複数の環境に同様にデプロイできるコンテナー イメージを作成できます。 コンテナーは、ホスト ファイル システムに影響を与えることなくチーム間でコードを共有し、開発環境をブートストラップするための簡単なメカニズムとして機能します。

コンテナーは、移植性と汎用性を備えており、あらゆる言語で作成されたアプリを実行できます。また、Windows 10 バージョン 1607 以降、または Windows Server 2016 以降を実行しているすべてのコンピューターと互換性があります。 開発者は、コンテナーをノート PC やデスクトップでローカルに作成してテストし、その同じコンテナー イメージを会社のプライベート クラウド、パブリック クラウド、またはサービス プロバイダーにデプロイできます。 コンテナーに備わっている機敏性が、大規模で仮想化されたクラウド環境における最新のアプリ開発パターンをサポートします。 開発者にとって最も便利な利点はおそらく、指定したバージョンのライブラリをアプリで常に取得して依存関係との競合を回避できるように、環境を分離できる点です。

IT プロフェッショナル向けのコンテナー

管理者は、コンテナーを使用することにより、更新と保守が容易で、ハードウェア リソースをより完全に活用するインフラストラクチャを作成することができます。 IT プロフェッショナルは、コンテナーを使用して、開発、品質保証、運用の各チームに標準化された環境を提供することができます。 システム管理者は、コンテナーを使用することにより、オペレーティング システムのインストールと基礎となるインフラストラクチャの違いを取り除きます。

コンテナーの対話型モードを使用して、同じシステム上でコマンド ライン ツールの競合する複数のインスタンスを実行することもできます。

コンテナーのオーケストレーション

オーケストレーターは、コンテナー ベースの環境をセットアップする際のインフラストラクチャの重要な部分です。 Docker と Windows を使用していくつかのコンテナーを手動で管理することもできますが、多くの場合、アプリでは 5 個、10 個、または数百個ものコンテナーが使用されるため、オーケストレーターが必要となります。

コンテナーのオーケストレーターは、コンテナーの管理を大規模に運用環境で行うために構築されました。 オーケストレーターは、次の機能を提供します。

オーケストレーターは、コンテナー化されたアプリを大規模に拡張するのに役立ち、次の機能も備えています。

  • 大規模なデプロイ
  • ワークロードのスケジュール設定
  • ヘルスの監視
  • ノードで障害が発生したときのフェールオーバー
  • スケールアップまたはスケールダウン
  • ネットワーク
  • サービス検出
  • アプリのアップグレードの調整
  • クラスタ ノードのアフィニティ

Windows コンテナーでは、さまざまな種類のオーケストレーターを使用できます。Microsoft では次のオプションを提供しています。

Windows でコンテナーを試す

Windows Server または Windows 10 でコンテナーの使用を開始するには、次を参照してください。

自分のシナリオに適した Azure サービスを決定するには、Azure コンテナー サービスアプリケーションをホストするために使用する Azure サービスの選択に関する記事を参照してください。

リソース

Windows Server コンテナーの使用に関するリソースを確認するには: