k8s更新策略-系列文章第一篇:蓝绿发布

简介: k8s更新策略-系列文章第一篇:蓝绿发布

10.1 什么是蓝绿部署?

蓝绿部署中,一共有两套系统:一套是正在提供服务系统,标记为“绿色”;另一套是准备发布的系统,标记为“蓝色”。两套系统都是功能完善的、正在运行的系统,只是系统版本和对外服务情况不同。

开发新版本,要用新版本替换线上的旧版本,在线上的系统之外,搭建了一个使用新版本代码的全新系统。这时候,一共有两套系统在运行,正在对外提供服务的老系统是绿色系统,新部署的系统是蓝色系统。

蓝色系统不对外提供服务,用来做什么呢?

用来做发布前测试,测试过程中发现任何问题,可以直接在蓝色系统上修改,不干扰用户正在使用的系统。(注意,两套系统没有耦合的时候才能百分百保证不干扰)

蓝色系统经过反复的测试、修改、验证,确定达到上线标准之后,直接将用户切换到蓝色系统:

切换后的一段时间内,依旧是蓝绿两套系统并存,但是用户访问的已经是蓝色系统。这段时间内观察蓝色系统(新系统)工作状态,如果出现问题,直接切换回绿色系统。

 

当确信对外提供服务的蓝色系统工作正常,不对外提供服务的绿色系统已经不再需要的时候,蓝色系统正式成为对外提供服务系统,成为新的绿色系统。原先的绿色系统可以销毁,将资源释放出来,用于部署下一个蓝色系统。


10.2 蓝绿部署的优势和缺点

优点:

1、更新过程无需停机,风险较少

2、回滚方便,只需要更改路由或者切换DNS服务器,效率较高

缺点:

1、成本较高,需要部署两套环境。如果新版本中基础服务出现问题,会瞬间影响全网用户;如果新版本有问题也会影响全网用户。

2、需要部署两套机器,费用开销大

3、在非隔离的机器(Docker、VM)上操作时,可能会导致蓝绿环境被摧毁风险

4、负载均衡器/反向代理/路由/DNS处理不当,将导致流量没有切换过来情况出现

 

11、通过k8s实现线上业务的蓝绿部署

 

下面实验需要的镜像包在课件,把镜像压缩包上传到k8s的各个工作节点,docker load -i解压:

[root@xianchaonode2 ~]# docker load -i myapp-lan.tar.gz
[root@xianchaonode1 ~]# docker load -i myapp-lv.tar.gz

Kubernetes不支持内置的蓝绿部署。目前最好的方式是创建新的deployment,然后更新应用程序的service以指向新的deployment部署的应用

 

1.创建蓝色部署环境(新上线的环境,要替代绿色环境)

 

下面步骤在k8s的控制节点操作:

[root@xianchaomaster1 ~]# kubectl create ns blue-green
[root@xianchaomaster1 ~]# cat  lan.yaml
apiVersion: apps/v1
kind: Deployment
metadata:
  name: myapp-v1
  namespace:blue-green
spec:
  replicas: 3
  selector:
   matchLabels:
    app: myapp
   version: v1
  template:
   metadata:
    labels:
     app: myapp
     version: v1
   spec:
    containers:
    - name: myapp
      image:janakiramm/myapp:v1
     imagePullPolicy: IfNotPresent
      ports:
      - containerPort: 80

然后可以使用kubectl命令创建部署。

[root@xianchaomaster1~]# kubectl apply -f lan.yaml

验证部署是否成功:

[root@xianchaomaster1~]# kubectl get pods -n blue-green

显示如下:

NAME                        READY   STATUS   RESTARTS   AGE
myapp-v1-67fd9fc9c8-tsl92   1/1    Running   0          53s
myapp-v1-67fd9fc9c8-24tbp   1/1    Running   0          53s
myapp-v1-67fd9fc9c8-cw59c   1/1    Running   0          53s

2.创建绿色部署环境(原来的部署环境)

[root@xianchaomaster1 ~]# cat  lv.yaml
apiVersion: apps/v1
kind: Deployment
metadata:
  name: myapp-v2
  namespace:blue-green
spec:
  replicas: 3
  selector:
   matchLabels:
    app: myapp
    version: v2
  template:
   metadata:
    labels:
     app: myapp
     version: v2
   spec:
    containers:
    - name: myapp
      image:janakiramm/myapp:v2
     imagePullPolicy: IfNotPresent
      ports:
      -containerPort: 80

可以使用kubectl命令创建部署。

[root@xianchaomaster1~]# kubectl apply -f lv.yaml

创建前端service

[root@xianchaomaster1 ~]# cat service_lanlv.yaml
apiVersion: v1
kind: Service
metadata:
  name: myapp-lan
  namespace:blue-green
  labels:
    app: myapp
    version: v2
spec:
  type: NodePort
  ports:
  - port: 80
    nodePort: 30062
    name: http
  selector:
    app: myapp
version: v2

更新服务:

[root@xianchaomaster1~]# kubectl apply -f service_lanlv.yaml

在浏览器访问http://k8s-master节点ip:30062 显示如下:


 

修改service_lanlv.yaml 配置文件,修改标签,让其匹配到蓝程序(升级之后的程序)

[root@xianchaomaster1 ~]# cat service_lanlv.yaml
apiVersion: v1
kind: Service
metadata:
  name: myapp-lan
  namespace:blue-green
  labels:
    app: myapp
    version: v1
spec:
  type: NodePort
  ports:
  - port: 80
    nodePort: 30062
    name: http
  selector:
    app: myapp
    version: v1

更新资源清单文件:

[root@xianchaomaster1~]# kubectl apply -f service_lanlv.yaml

在浏览器访问http://k8s-master节点ip:30062 显示如下:

相关实践学习
通过Ingress进行灰度发布
本场景您将运行一个简单的应用,部署一个新的应用用于新的发布,并通过Ingress能力实现灰度发布。
容器应用与集群管理
欢迎来到《容器应用与集群管理》课程,本课程是“云原生容器Clouder认证“系列中的第二阶段。课程将向您介绍与容器集群相关的概念和技术,这些概念和技术可以帮助您了解阿里云容器服务ACK/ACK Serverless的使用。同时,本课程也会向您介绍可以采取的工具、方法和可操作步骤,以帮助您了解如何基于容器服务ACK Serverless构建和管理企业级应用。 学习完本课程后,您将能够: 掌握容器集群、容器编排的基本概念 掌握Kubernetes的基础概念及核心思想 掌握阿里云容器服务ACK/ACK Serverless概念及使用方法 基于容器服务ACK Serverless搭建和管理企业级网站应用
目录
打赏
0
1
1
1
36
分享
相关文章
"Kubernetes的生死抉择:揭秘Pod容器重启策略如何决定应用命运的惊天大戏"
【8月更文挑战第20天】Kubernetes (k8s) 是一个强大的容器编排平台,其中Pod是最小的运行单元。Pod的重启策略确保服务连续性,主要有Always(总是重启)、OnFailure(失败时重启)和Never(从不重启)。默认策略为Always。根据不同场景,如Web服务、批处理作业或一次性任务,可以选择合适的策略。K8s还支持健康检查等高级机制来控制容器重启。合理配置这些策略对维护应用稳定性至关重要。
199 4
K8s业务迁移最佳实践: 灵活管理资源备份与调整策略,实现高效简便的应用恢复
在当今快速变化的云原生领域,Kubernetes(K8s)集群的运维面临着诸多挑战,其中灾备与业务迁移尤为关键。ACK备份中心支持丰富的资源调整策略,在数据恢复阶段即可自动适配目标集群环境,确保业务无缝重启。
如何设置 Kubernetes的垃圾回收策略为定期
如何设置 Kubernetes的垃圾回收策略为定期
Kubernetes中的Pod垃圾回收策略是什么
Kubernetes中的Pod垃圾回收策略是什么
k8s学习--kubernetes服务自动伸缩之水平收缩(pod副本收缩)VPA策略应用案例
k8s学习--kubernetes服务自动伸缩之水平收缩(pod副本收缩)VPA策略应用案例
105 1
Kubernetes系统安全-授权策略(authorization policy)
文章主要介绍了Kubernetes系统中的授权策略,包括授权模块的概述、RBAC授权模块的详细说明以及如何创建和管理角色(Role)和集群角色(ClusterRole)。
86 0
Kubernetes系统安全-授权策略(authorization policy)
在K8S中,如何实现金丝雀发布(灰度发布)?蓝绿发布?
在K8S中,如何实现金丝雀发布(灰度发布)?蓝绿发布?
在k8S中,镜像的下载策略有哪些?
在k8S中,镜像的下载策略有哪些?

热门文章

最新文章

AI助理

你好,我是AI助理

可以解答问题、推荐解决方案等