0%

伸缩服务和滚动更新

通过更改部署中的 replicas(副本数)来完成伸缩

Scaling(伸缩)应用程序

伸缩 的实现可以通过更改 nginx-deployment.yaml 文件中部署的 replicas(副本数)来完成

1
2
spec:
replicas: 4 #使用该Deployment创建两个应用程序实例

修改了 Deployment 的 replicas 为 4 后,Kubernetes 又为该 Deployment 创建了 3 新的 Pod,这 4 个 Pod 有相同的标签。因此Service A通过标签选择器与新的 Pod建立了对应关系,将访问流量通过负载均衡在 4 个 Pod 之间进行转发。

Kubernetes教程:伸缩

将 nginx Deployment 扩容到 4 个副本

修改 nginx-deployment.yaml 文件,将 replicas 修改为 4

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
apiVersion: apps/v1
kind: Deployment
metadata:
name: nginx-deployment
labels:
app: nginx
spec:
replicas: 4 #通过更改部署中的 replicas(副本数)来完成扩展
selector:
matchLabels:
app: nginx
template:
metadata:
labels:
app: nginx
spec:
containers:
- name: nginx
image: nginx:1.7.9
ports:
- containerPort: 80

执行命令:

1
2
3
4
kubectl apply -f nginx-deployment.yaml

#查看结果
watch kubectl get pods -o wide

滚动更新

用户期望应用程序始终可用,为此开发者/运维者在更新应用程序时要分多次完成。在 Kubernetes 中,这是通过 Rolling Update 滚动更新完成的。Rolling Update滚动更新 通过使用新版本的 Pod 逐步替代旧版本的 Pod 来实现 Deployment 的更新,从而实现零停机。新的 Pod 将在具有可用资源的 Node(节点)上进行调度。

Kubernetes 更新多副本的 Deployment 的版本时,会逐步的创建新版本的 Pod,逐步的停止旧版本的 Pod,以便使应用一直处于可用状态。这个过程中,Service 能够监视 Pod 的状态,将流量始终转发到可用的 Pod 上。

滚动更新步骤

1.原本 Service A 将流量负载均衡到 4 个旧版本的 Pod (当中的容器为 绿色)上

1.原本 Service A 将流量负载均衡到 4 个旧版本的 Pod (当中的容器为 绿色)上

Kubernetes教程:滚动更新1

2.更新完 Deployment 部署文件中的镜像版本后,master 节点选择了一个 worker 节点,并根据新的镜像版本创建 Pod(紫色容器)。新 Pod 拥有唯一的新的 IP。同时,master 节点选择一个旧版本的 Pod 将其移除。

此时,Service A 将新 Pod 纳入到负载均衡中,将旧Pod移除

Kubernetes教程:滚动更新2

  1. 同步骤2,再创建一个新的 Pod 替换一个原有的 Pod Kubernetes教程:滚动更新3

  2. 如此 Rolling Update 滚动更新,直到所有旧版本 Pod 均移除,新版本 Pod 也达到 Deployment 部署文件中定义的副本数,则滚动更新完成

    更新 nginx Deployment

修改 nginx-deployment.yaml 文件
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
apiVersion: apps/v1
kind: Deployment
metadata:
name: nginx-deployment
labels:
app: nginx
spec:
replicas: 4
selector:
matchLabels:
app: nginx
template:
metadata:
labels:
app: nginx
spec:
containers:
- name: nginx
image: nginx:1.8 #使用镜像nginx:1.8替换原来的nginx:1.7.9
ports:
- containerPort: 80

执行命令

1
2
3
4
kubectl apply -f nginx-deployment.yaml

#查看过程及结果,可观察到 pod 逐个被替换的过程。
watch kubectl get pods -l app=nginx