OpenShift-DockerとKubernetes

OpenShiftは、DockerとKubernetesの上に構築されています。すべてのコンテナは、基本的にLinuxマシン上のKubernetesサービスであるDockerクラスター上に構築され、Kubernetesオーケストレーション機能を使用します。

このプロセスでは、すべてのノードを制御し、コンテナをすべてのノードにデプロイするKubernetesマスターを構築します。Kubernetesの主な機能は、異なる種類の設定ファイルを使用してOpenShiftクラスターとデプロイメントフローを制御することです。Kubernetesと同様に、OCコマンドラインユーティリティを使用してクラスターノードにコンテナーをビルドおよびデプロイするのと同じ方法でkubctlを使用します。

以下は、クラスター内のさまざまな種類のオブジェクトの作成に使用されるさまざまな種類の構成ファイルです。

  • Images
  • POD
  • Service
  • レプリケーションコントローラー
  • レプリカセット
  • Deployment

画像

Kubernetes(Docker)イメージは、コンテナ化されたインフラストラクチャの主要な構成要素です。現在のところ、KubernetesはサポートしているだけですDocker画像。ポッド内の各コンテナには、Dockerイメージが実行されています。

apiVersion: v1
kind: pod
metadata:
   name: Tesing_for_Image_pull -----------> 1
   spec:
   containers:
- name: neo4j-server ------------------------> 2
image: <Name of the Docker image>----------> 3
imagePullPolicy: Always ------------->4
command: [“echo”, “SUCCESS”] -------------------> 5

POD

ポッドは、Kubernetesクラスターのノード内のコンテナーとそのストレージのコレクションです。内部に複数のコンテナを含むポッドを作成することができます。以下は、データベースコンテナとWebインターフェイスコンテナを同じポッドに保持する例です。

apiVersion: v1
kind: Pod
metadata:
   name: Tomcat
spec:
   containers:
   - name: Tomcat
      image: tomcat: 8.0
      ports:
- containerPort: 7500
imagePullPolicy: Always

サービス

サービスは、ポッドの論理セットとして定義できます。これは、ポッドにアクセスできる単一のIPアドレスとDNS名を提供するポッド上部の抽象化として定義できます。Serviceを使用すると、負荷分散構成の管理が非常に簡単になります。これは、PODを非常に簡単にスケーリングするのに役立ちます。

apiVersion: v1
kind: Service
metadata:
   name: Tutorial_point_service
spec:
   ports:
   - port: 8080
      targetPort: 31999

レプリケーションコントローラー

レプリケーションコントローラーは、ポッドのライフサイクルの管理を担当するKubernetesの重要な機能の1つです。指定された数のポッドレプリカがいつでも実行されていることを確認する責任があります。

apiVersion: v1
kind: ReplicationController
metadata:
   name: Tomcat-ReplicationController
spec:
   replicas: 3
   template:
   metadata:
      name: Tomcat-ReplicationController
   labels:
      app: App
      component: neo4j
   spec:
      containers:
      - name: Tomcat
      image: tomcat: 8.0
      ports:
      - containerPort: 7474

レプリカセット

レプリカセットは、実行するポッドのレプリカの数を保証します。これは、レプリケーションコントローラーの代替と見なすことができます。

apiVersion: extensions/v1beta1
kind: ReplicaSet
metadata:
   name: Tomcat-ReplicaSet
spec:
   replicas: 3
   selector:
      matchLables:
      tier: Backend
   matchExpression:
      - { key: tier, operation: In, values: [Backend]}
   
   app: App
   component: neo4j
spec:
   containers:
   - name: Tomcat-
image: tomcat: 8.0
   ports:
containerPort: 7474

展開

デプロイメントはアップグレードされ、レプリケーションコントローラーの上位バージョンになります。これらは、レプリケーションコントローラーのアップグレードバージョンでもあるレプリカセットの展開を管理します。レプリカセットを更新する機能があり、以前のバージョンにロールバックすることもできます。

apiVersion: extensions/v1beta1 --------------------->1
kind: Deployment --------------------------> 2
metadata:
   name: Tomcat-ReplicaSet
spec:
   replicas: 3
   template:
      metadata:
lables:
   app: Tomcat-ReplicaSet
   tier: Backend
spec:
   containers:
name: Tomcat-
   image: tomcat: 8.0
   ports:
   - containerPort: 7474

すべての設定ファイルを使用して、それぞれのKubernetesオブジェクトを作成できます。

$ Kubectl create –f <file name>.yaml

次のコマンドを使用して、Kubernetesオブジェクトの詳細と説明を知ることができます。

For POD

$ Kubectl get pod <pod name>
$ kubectl delete pod <pod name>
$ kubectl describe pod <pod name>

For Replication Controller

$ Kubectl get rc <rc name>
$ kubectl delete rc <rc name>
$ kubectl describe rc <rc name>

For Service

$ Kubectl get svc <svc name>
$ kubectl delete svc <svc name>
$ kubectl describe svc <svc name>

DockerとKubernetesの操作方法の詳細については、次のリンクkubernetesを使用してKubernetesチュートリアルにアクセスしてください。