OpenShift-アーキテクチャー
OpenShiftは、KubernetesとDockerクラスターを使用して各レイヤーが他のレイヤーと緊密にバインドされたレイヤードシステムです。OpenShiftのアーキテクチャーは、Kubernetesを使用してすべてのレイヤーの上でホストされるDockerコンテナーをサポートおよび管理できるように設計されています。以前のバージョンのOpenShiftV2とは異なり、新しいバージョンのOpenShiftV3はコンテナー化されたインフラストラクチャーをサポートします。このモデルでは、Dockerは軽量Linuxベースのコンテナーの作成を支援し、Kubernetesは複数のホスト上のコンテナーを調整および管理するタスクをサポートします。
OpenShiftのコンポーネント
OpenShiftアーキテクチャーの重要なコンポーネントの1つは、Kubernetesでコンテナー化されたインフラストラクチャーを管理することです。Kubernetesは、インフラストラクチャのデプロイと管理を担当します。どのKubernetesクラスターでも、複数のマスターと複数のノードを使用できるため、セットアップで障害が発生することはありません。
Kubernetesマスターマシンコンポーネント
Etcd−クラスター内の各ノードで使用できる構成情報を格納します。これは、複数のノードに分散できる高可用性のKey ValueStoreです。機密情報が含まれている可能性があるため、KubernetesAPIサーバーからのみアクセスできるようにする必要があります。これは、すべての人がアクセスできる分散型KeyValueストアです。
API Server− Kubernetesは、APIを使用してクラスター上のすべての操作を提供するAPIサーバーです。APIサーバーは、さまざまなツールやライブラリが簡単に通信できることを意味するインターフェイスを実装しています。kubeconfigは、通信に使用できるサーバー側ツールと一緒のパッケージです。KubernetesAPIを公開します。」
Controller Manager−このコンポーネントは、クラスターの状態を調整してタスクを実行するほとんどのコレクターを担当します。これは、非終了ループで実行され、情報の収集とAPIサーバーへの送信を担当するデーモンと見なすことができます。これは、クラスターの共有状態を取得し、サーバーの現在のステータスを目的の状態にするために変更を加えるために機能します。主要なコントローラーは、レプリケーションコントローラー、エンドポイントコントローラー、名前空間コントローラー、およびサービスアカウントコントローラーです。コントローラマネージャは、ノードやエンドポイントなどを処理するためにさまざまな種類のコントローラを実行します。
Scheduler−これはKubernetesマスターの重要なコンポーネントです。これは、ワークロードの分散を担当するマスターのサービスです。クラスタノードの作業負荷の使用率を追跡し、リソースが利用可能なワークロードを配置して、ワークロードを受け入れる役割を果たします。つまり、これは利用可能なノードにポッドを割り当てるためのメカニズムです。スケジューラーは、ワークロードの使用率とポッドの新しいノードへの割り当てを担当します。
Kubernetesノードコンポーネント
以下は、Kubernetesマスターと通信するために必要なノードサーバーの主要コンポーネントです。
Docker −各ノードの最初の要件はDockerです。これは、比較的分離されているが軽量のオペレーティング環境でカプセル化されたアプリケーションコンテナを実行するのに役立ちます。
Kubelet Service−これは各ノードの小さなサービスであり、コントロールプレーンサービスとの間で情報を中継する役割を果たします。etcdストアと対話して、構成の詳細とWright値を読み取ります。これはマスターコンポーネントと通信して、コマンドを受信して動作します。その後、kubeletプロセスは、作業状態とノードサーバーを維持する責任を負います。ネットワークルール、ポートフォワーディングなどを管理します。
Kubernetes Proxy Service−これは、各ノードで実行されるプロキシサービスであり、外部ホストがサービスを利用できるようにするのに役立ちます。リクエストを正しいコンテナに転送するのに役立ちます。Kubernetes Proxy Serviceは、プリミティブな負荷分散を実行できます。これにより、ネットワーク環境が予測可能でアクセス可能であると同時に、分離されていることが保証されます。ノード上のポッド、ボリューム、シークレットを管理し、新しいコンテナのヘルスチェックを作成します。
統合されたOpenShiftContainer Registry
OpenShiftコンテナーレジストリーは、Dockerイメージを保存するために使用されるRedHatの組み込みストレージユニットです。OpenShiftの最新の統合バージョンでは、OpenShift内部ストレージ内の画像を表示するためのユーザーインターフェイスが用意されています。これらのレジストリは、指定されたタグを持つイメージを保持することができ、後でそれからコンテナを構築するために使用されます。
よく使われる用語
Image− Kubernetes(Docker)イメージは、コンテナ化されたインフラストラクチャの主要な構成要素です。現在のところ、KubernetesはDockerイメージのみをサポートしています。ポッド内の各コンテナには、Dockerイメージが実行されています。ポッドを構成する場合、構成ファイルのimageプロパティの構文はDockerコマンドと同じです。
Project −以前のバージョンのOpenShiftV2に存在していたドメインの名前が変更されたバージョンとして定義できます。
Container −イメージがKubernetesクラスターノードにデプロイされた後に作成されるものです。
Node−ノードはKubernetesクラスター内で動作するマシンであり、マスターのミニオンとも呼ばれます。これらは、物理インスタンス、VMインスタンス、またはクラウドインスタンスを実行できる作業ユニットです。
Pod−ポッドは、Kubernetesクラスターのノード内のコンテナーとそのストレージのコレクションです。内部に複数のコンテナを含むポッドを作成することができます。たとえば、データベースコンテナとWebサーバーコンテナをポッド内に保持します。