21、Kubernetes 实战 - 控制器之Deployment
简介
一个Deployment 控制器为 Pods 和 ReplicaSets 提供声明式的更新能力。Deployment 是最常用的用于部署无状态服务的方式。
你负责描述 Deployment 中的 目标状态,而 Deployment 控制器以受控速率更改实际状态, 使其变为期望状态。你可以定义 Deployment 以创建新的 ReplicaSet,或删除现有 Deployment, 并通过新的 Deployment 收养其资源。
使用方式
以下是Deployment 的典型用例:
- 定义Deployment 来创建Pod和ReplicaSet
- 滚动升级和回滚应用
- 自动伸缩
- 暂停和继续Deployment
创建
vim nginx-deploy.yaml
apiVersion: apps/v1
kind: Deployment
metadata:
Deployment名称
name: nginx-deployment
labels:
app: nginx
spec:
Pod 副本数量
replicas: 3
定义 Deployment 如何查找要管理的 Pods
selector:
matchLabels:
app: nginx
template:
metadata:
labels:
app: nginx
spec:
containers:
- name: nginx
image: daocloud.io/library/nginx:1.7.11
ports:
- containerPort: 80
# 你可以设置 --record 标志将所执行的命令写入资源注解 kubernetes.io/change-cause 中。 这对于以后的检查是有用的。例如,要查看针对每个 Deployment 修订版本所执行过的命令。
kubectl create -f nginx-deploy.yaml --record
kubectl get deployments
# 查看 Deployment 上线状态
kubectl rollout status deployment.v1.apps/nginx-deployment
# 会自动创建rs
kubectl get rs
# 查看每个 Pod 自动生成的标签
kubectl get pods --show-labels
deployment字段说明
- NAME 列出了集群中 Deployment 的名称。
- READY 显示应用程序的可用的 副本 数。显示的模式是“就绪个数/期望个数”。
- UP-TO-DATE 显示为了打到期望状态已经更新的副本数。
- AVAILABLE 显示应用可供用户使用的副本数。
- AGE 显示应用程序运行的时间。
ReplicaSet 字段说明:
- NAME 列出名字空间中 ReplicaSet 的名称;
- DESIRED 显示应用的期望副本个数,即在创建 Deployment 时所定义的值。 此为期望状态;
- CURRENT 显示当前运行状态中的副本个数;
- READY 显示应用中有多少副本可以为用户提供服务;
- AGE 显示应用已经运行的时间长度。
注意ReplicaSet 的名称始终被格式化为[Deployment名称]-[随机字符串]。 其中的随机字符串是使用 pod-template-hash 作为种子随机生成的
扩容
kubectl scale deployment nginx-deployment --replicas 5
自动扩容
kubectl autoscale deployment nginx-deployment --min=1 --max=5 --cpu-percent=80
更新镜像版本
# 将ngixn更新到1.9.2
kubectl set image deployment/nginx-deployment nginx=daocloud.io/library/nginx:1.9.2
#
kubectl describe deployment nginx-deployment
回滚版本
kubectl rollout undo deployment/nginx-deployment
# 查看回滚状态
kubectl rollout status deployment.v1.apps/nginx-deployment
# 查看历史版本
kubectl rollout history deployment/nginx-deployment
# 指定版本查看修订历史的详细信息
kubectl rollout history deployment/nginx-deployment --revision=4
# 指定版本回滚
kubectl rollout undo deployment/nginx-deployment --to-revision=3
# 暂定更新
kubectl rollout pause deployment/nginx-deployment