Kubernetes - 复制控制器

复制控制器是 Kubernetes 的关键特性之一,它负责管理 pod 生命周期。 它负责确保指定数量的 pod 副本在任何时间点都在运行。 当需要确保指定数量的 pod 或至少一个 pod 正在运行时,会及时使用它。 它具有开启或关闭指定数量的 pod 的能力。

最佳实践是使用复制控制器来管理 pod 生命周期,而不是一次又一次地创建 pod。

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

设置详情

  • Kind: ReplicationController → 在上面的代码中,我们将类型定义为复制控制器,它告诉 kubectl yaml 文件将用于创建复制控制器。

  • name: Tomcat-ReplicationController → 这有助于识别将创建复制控制器的名称。 如果我们运行 kubctl,获取 rc < Tomcat-ReplicationController > 它将显示复制控制器的详细信息。

  • replicas: 3 → 这有助于复制控制器了解它需要在 pod 生命周期的任何时间点维护 pod 的三个副本。

  • name: Tomcat → 在规范部分,我们将名称定义为 tomcat,这将告诉复制控制器 Pod 中存在的容器是 tomcat。

  • containerPort: 7474 → 它有助于确保集群中运行 Pod 的容器的所有节点都暴露在同一端口 7474 上。

Kube 副本服务

这里,Kubernetes 服务作为三个 tomcat 副本的负载平衡器。