Kubernetes滚动更新实战

1、滚动更新简介

当某个服务需要升级时,传统的做法是,先将要更新的服务下线,业务停止后再更新版本和配置,然后重新启动服务。如果业务集群规模较大时,这个工作就变成了一个挑战,而且全部停止了服务,再逐步升级的方式会导致服务较长时间不可用。针对这个问题,k8s提供了滚动更新(rolling-update)的方式来解决上述问题。

滚动更新是针对pod来操作的,它通过一次只更新一小部分副本,成功后,再更新更多的副本,最终完成所有副本的更新。滚动更新的最大的好处是零停机,整个更新过程始终有副本在运行,从而保证了服务的连续性。

2、滚动更新实现

下面我们部署一个http应用,三个副本,初始镜像为 httpd:2.4.33,然后将其更新到 httpd:2.4.38。编写一个Deployment文件http.yml,内容如下:

apiVersion: apps/v1
kind: Deployment
metadata:
  name: httpd2.4.33-deployment
spec:
  replicas: 3
  selector:
   matchLabels:
     app: httpd
  template:
    metadata:
      labels:
        app: httpd
    spec:
      containers:
      - name: httpd
        image: httpd:2.4.33
        ports:
        - containerPort: 80

然后执行这个文件,并查看状态,执行如下命令:

[root@master k8s]# kubectl apply -f httpd.yml
[root

猜你喜欢

转载自blog.csdn.net/qq_35029061/article/details/132201031