深入浅出 Kubernetes:浅谈 Deployment 和 ReplicaSet
- 2019 年 10 月 4 日
- 筆記
版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/solaraceboy/article/details/98883311
文章目录
深入浅出 Kubernetes:浅谈 Deployment 和 ReplicaSet
一 背景
Deployment 和 ReplicaSet 是 Kubernetes 中两个比较重要的对象,本文简单地讨论了他们之间的一些区别与联系。
二 Deployment
apiVersion: apps/v1 kind: Deployment metadata: name: deployment-gysl spec: replicas: 2 selector: matchLabels: app-1: nginx app-2: busybox template: metadata: labels: app-1: nginx app-2: busybox spec: containers: - name: app-1 image: nginx:1.16.0 imagePullPolicy: Always ports: - containerPort: 80 - containerPort: 8080 - name: app-2 image: busybox imagePullPolicy: Never command: ['/bin/sh', '-c'] args: - while :;do sleep 20;done
这是一个编排得非常简单的 Deployment,确保携带 app-1=nginx 和 app-2=busybox 标签的 Pod 的个数等于 spec.replicas 指定的总数 2 个。也就是说在这个 Deployment 的 Pod 数量大等于2时,就会有 Pod 被删除,反之则会有 Pod 被创建。
这个 Deployment 由2个部分构成,例子中的 yaml 第1-10行定义了 Deployment 控制器,第10行以后的内容则定义了被控制的 Pod ,template 后面这一部分我们会发现跟之前的 Pod 定义大同小异。
此处顺便提一条命令(更新 Deployment 的镜像):
kubectl set image deployment/deployment-gysl app-1=nginx:latest
这个命令还可以更新以下对象:
env Update environment variables on a pod template image 更新一个 pod template 的镜像 resources 在对象的 pod templates 上更新资源的 requests/limits selector 设置 resource 的 selector serviceaccount Update ServiceAccount of a resource subject Update User, Group or ServiceAccount in a RoleBinding/ClusterRoleBinding
三 ReplicaSet
apiVersion: apps/v1 kind: ReplicaSet metadata: name: replica-set-gysl spec: selector: matchLabels: app: nginx replicas: 2 template: metadata: name: nginx labels: app: nginx spec: containers: - name: nginx image: nginx:latest
一个 ReplicaSet 对象就是由副本数目的定义和一个 Pod 模板组成的, 它的定义就是 Deployment 的一个子集。Deployment 控制器实际操纵的是 ReplicaSet 对象,而不是 Pod 对象。
ReplicaSet 负责通过“控制器模式”,保证系统中 Pod 的个数永远等于指定的个数(比如,2 个)。这也正是 Deployment 只允许容器的 restartPolicy=Always 的主要原因:只有在容器能保证自己始终是 Running 状态的前提下,ReplicaSet 调整 Pod 的个数才有意义。
Deployment 通过“控制器模式”,来操作 ReplicaSet 的个数和属性,进而实现“水平扩展 / 收缩”和“滚动更新”这两个编排动作。
四 其他
在之前的文章中已经讨论过 Kubernetes 中的滚动更新,这是 Deployment 控制器与 ReplicaSet 的最大不同之处,也是 Deployment 被广泛使用的最主要原因。