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,并支持滚动升级、回退版本
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