OpenShift - Docker e Kubernetes

O OpenShift é baseado no Docker e no Kubernetes. Todos os contêineres são construídos sobre o cluster do Docker, que é basicamente um serviço Kubernetes sobre as máquinas Linux, usando o recurso de orquestrações do Kubernetes.

Nesse processo, construímos o mestre Kubernetes, que controla todos os nós e implanta os contêineres em todos os nós. A principal função do Kubernetes é controlar o cluster OpenShift e o fluxo de implantação usando um tipo diferente de arquivo de configuração. Como no Kubernetes, usamos kubctl da mesma forma que usamos o utilitário de linha de comando OC para construir e implantar contêineres em nós de cluster.

A seguir estão os diferentes tipos de arquivos de configuração usados ​​para a criação de diferentes tipos de objetos no cluster.

  • Images
  • POD
  • Service
  • Controlador de Replicação
  • Conjunto de réplicas
  • Deployment

Imagens

As imagens do Kubernetes (Docker) são os principais blocos de construção da infraestrutura em contêiner. A partir de agora, o Kubernetes oferece suporte apenasDockerimagens. Cada contêiner em um pod tem sua imagem Docker em execução dentro dele.

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

Um pod é uma coleção de contêineres e seu armazenamento dentro de um nó de um cluster do Kubernetes. É possível criar um pod com vários contêineres dentro dele. A seguir está um exemplo de como manter um contêiner de banco de dados e um contêiner de interface da web no mesmo pod.

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

Serviço

Um serviço pode ser definido como um conjunto lógico de pods. Ele pode ser definido como uma abstração no topo do pod que fornece um único endereço IP e nome DNS pelo qual os pods podem ser acessados. Com o Service, é muito fácil gerenciar a configuração de balanceamento de carga. Ajuda os PODs a escalar facilmente.

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

Controlador de Replicação

O controlador de replicação é um dos principais recursos do Kubernetes, responsável por gerenciar o ciclo de vida do pod. Ele é responsável por garantir que um número especificado de réplicas de pod estejam em execução a qualquer momento.

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

Conjunto de réplicas

O conjunto de réplicas garante quantas réplicas de pod devem estar em execução. Pode ser considerado uma substituição do controlador de replicação.

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

Desdobramento, desenvolvimento

As implantações são atualizadas e versões superiores do controlador de replicação. Eles gerenciam a implantação de conjuntos de réplicas, que também são uma versão atualizada do controlador de replicação. Eles têm a capacidade de atualizar o conjunto de réplicas e também podem retornar à versão anterior.

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

Todos os arquivos de configuração podem ser usados ​​para criar seus respectivos objetos Kubernetes.

$ Kubectl create –f <file name>.yaml

Os comandos a seguir podem ser usados ​​para saber os detalhes e a descrição dos objetos 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>

Para obter mais detalhes sobre como trabalhar com Docker e Kubernetes, visite nosso tutorial do Kubernetes usando o seguinte link kubernetes .