K8S - deployment - 外

1、简介

在kubernetes中,Pod是最小的控制单元,但是kubernetes很少直接控制Pod,一般都是通过Pod控制器来完成的。Pod控制器用于pod的管理,确保pod资源符合预期的状态,当pod的资源出现故障时,会尝试进行重启或重建pod。

1.1、pod的创建方式:

  • 自主式pod:kubernetes直接创建出来的Pod,这种pod删除后就没有了,也不会重建
  • 控制器创建的pod:kubernetes通过控制器创建的pod,这种pod删除了之后还会自动重建

1.2、pod的控制器

Pod控制器是管理pod的中间层,使用Pod控制器之后,只需要告诉Pod控制器,想要多少个什么样的Pod就可以了,它会创建出满足条件的Pod并确保每一个Pod资源处于用户期望的目标状态。如果Pod资源在运行中出现故障,它会基于指定策略重新编排Pod。
在kubernetes中,有很多类型的pod控制器,每种都有自己的适合的场景,常见的有下面这些:

  • ReplicationController:比较原始的pod控制器,已经被废弃,由ReplicaSet替代
  • ReplicaSet:保证副本数量一直维持在期望值,并支持pod数量扩缩容,镜像版本升级
  • Deployment:通过控制ReplicaSet来控制Pod,并支持滚动升级、回退版本
  • Horizontal Pod Autoscaler:可以根据集群负载自动水平调整Pod的数量,实现削峰填谷
  • DaemonSet:在集群中的指定Node上运行且仅运行一个副本,一般用于守护进程类的任务
  • Job:它创建出来的pod只要完成任务就立即退出,不需要重启或重建,用于执行一次性任务
  • Cronjob:它创建的Pod负责周期性任务控制,不需要持续后台运行
  • StatefulSet:管理有状态应用原文链接

1.3、deployment控制器

deployment通过控制ReplicaSet来控制Pod,并支持滚动升级、回退版本

k8s删除了docker路径 k8s删除deployment_kubernetes

2、创建deployment

参考kubernetes中文文档创建nginx,编辑文件k8s-nexus.yaml

apiVersion: apps/v1
kind: Deployment        # 指定Pod控制器为Deployment
metadata:
  name: nginx-deployment     #创建名为nginx-deployment的deployment
  labels:
    app: nginx               #标签
spec:
  replicas: 3         # 生产三个POD
  selector:  
    matchLabels:
      app: nginx     #匹配标签,管理pod
  template:
    metadata:
      labels:
        app: nginx    #为pod创建标签app
    spec:
      containers:
        - name: nginx
          image: nginx:1.14.2     # 镜像及版本
          ports:
            - containerPort: 80

2.1、运行ngnix

smy1102@LAPTOP-7HC3FEQ9 D:\minikube\source_data>kubectl apply -f k8s-nexus.yaml
deployment.apps/nginx-deployment created

smy1102@LAPTOP-7HC3FEQ9 D:\minikube\source_data>kubectl get pods
NAME                                READY   STATUS              RESTARTS   AGE
docker-demo-k8s-54db7b687d-sqqk9    1/1     Running             1          15d
mysql-647d7dc46f-2dnkz              1/1     Running             1          54d
nginx-deployment-6595874d85-2g6gc   0/1     ImagePullBackOff   0          65s
nginx-deployment-6595874d85-b28h2   0/1     ContainerCreating   0          65s
nginx-deployment-6595874d85-r4sh7   0/1     ContainerCreating   0          65s
recycler-for-mysql-pv               0/1     ImagePullBackOff    0          85s

查看pods信息,发现有状态为ImagePullBackOff,在minikube 快速使用入门 - pod - 外传中描述ImagePullBackOff”是正在拉去镜像的意思。这个时候修改一下镜像地址试一下。

2.2、修改一下镜像版本

smy1102@LAPTOP-7HC3FEQ9 D:\minikube\source_data>kubectl set image deployment/nginx-deployment nginx=nginx:1.16.1
deployment.apps/nginx-deployment image updated

smy1102@LAPTOP-7HC3FEQ9 D:\minikube\source_data>kubectl get pods
NAME                                READY   STATUS              RESTARTS   AGE
docker-demo-k8s-54db7b687d-sqqk9    1/1     Running             1          15d
mysql-647d7dc46f-2dnkz              1/1     Running             1          54d
nginx-deployment-66b957f9d-99krm    0/1     ContainerCreating   0          2s
nginx-deployment-6595874d85-2g6gc   1/1     Running             0          5m6s
nginx-deployment-6595874d85-b28h2   1/1     Running             0          5m6s
nginx-deployment-6595874d85-r4sh7   1/1     Running             0          5m6s

在拉取镜像的pod已经开始运行,修改镜像之后,会重新创建一个新的镜像。新的镜像名称nginx-deployment-66b957f9d-99krm,跟原来的镜像名称前缀匹配nginx-deployment,后缀为重新生成,新的单镜像,如果镜像版本是错误的,状态为ContainerCreating -〉ErrImagePull-〉 ImagePullBackOff-〉ErrImagePull-〉ImagePullBackOff,如果版本正确ContainerCreating -〉running。之后会删除之前的pod,重新依次生成三个新的镜像。

smy1102@LAPTOP-7HC3FEQ9 D:\minikube\source_data>kubectl get pods
NAME                               READY   STATUS    RESTARTS   AGE
docker-demo-k8s-54db7b687d-sqqk9   1/1     Running   1          15d
mysql-647d7dc46f-2dnkz             1/1     Running   1          54d
nginx-deployment-66b957f9d-99krm   1/1     Running   0          95m
nginx-deployment-66b957f9d-c7qbt   1/1     Running   0          95m
nginx-deployment-66b957f9d-wrfcv   1/1     Running   0          95m

2.3、查看副本

smy1102@LAPTOP-7HC3FEQ9 D:\minikube\source_data>kubectl get rs
NAME                          DESIRED   CURRENT   READY   AGE
docker-demo-k8s-54db7b687d    1         1         1       15d
mysql-647d7dc46f              1         1         1       54d
nginx-deployment-6595874d85   0         0         0       110m
nginx-deployment-66b957f9d    3         3         3       97m

2.4、查看状态

kubectl rollout status deployment/nginx-deployment

[参考][k8s] 第六章 Pod控制器详解 [参考]Deployments | Kubernetes