【kubernetes】蓝绿部署

概念:

蓝绿部署中,一共有两套系统:一套是正在提供服务系统,标记为"绿色";另一套是准备发布的系统,标记为"蓝色"。

两套系统都是功能完善的、正在运行的系统,只是系统版本和对外服务情况不同。

应用:

通过创建service服务 + 两套系统,可以做发布前的应用测试。

优缺点:

优点:

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

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

缺点:

1、如果新版本中基础服务出现问题,或者新版本有问题,会瞬间影响全网用户。

2、需要部署两套机器,对资源或硬件成本较高,费用开销大。

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

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

案例:

部署镜像下载:蓝绿部署环境.zip

创建命名空间:

python 复制代码
kubectl  create namespace[ns]  blue-green
第一步:部署绿色系统
python 复制代码
# vim lv.yaml

apiVersion: apps/v1
kind: Deployment
metadata:
  name: myapp-v1
  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
第二步:部署蓝色系统
python 复制代码
# vim lan.yaml

apiVersion: apps/v1
kind: Deployment
metadata:
  name: myapp-v2
  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
第三步:部署service服务
python 复制代码
# vim service-lanlv.yaml

apiVersion: v1
kind: Service
metadata:
  name: myapp-lan-lv
  namespace: blue-green
  labels:
    app: myapp
spec:
  type: NodePort
  ports:
  - port: 80
    nodePort: 30062
    name: http
  selector:
    app: myapp
    version: v1   # 修改切换 v1  和 v2 切换蓝绿部署

通过修改版本来访问,http://192.168.40.180:30062/ ,切换不一样的版本。

相关推荐
Britz_Kevin3 小时前
从零开始的云计算生活——第四十六天,铁杵成针,kubernetes模块之Configmap资源与Secret资源对象
kubernetes·云计算·生活
北i4 小时前
ZooKeeper 一致性模型解析:线性一致性与顺序一致性的平衡
分布式·zookeeper·云原生
Britz_Kevin4 小时前
从零开始的云计算生活——第四十七天,细水长流,kubernetes模块之ingress资源对象
kubernetes·云计算·生活
进击的阿尔法猿5 小时前
docker
运维·docker·容器
iceland97 小时前
kubeadm方式部署k8s集群
云原生·容器·kubernetes
wdxylb11 小时前
云原生俱乐部-shell知识点归纳(1)
linux·云原生
木易双人青13 小时前
01-Docker-简介、安装与使用
运维·docker·容器
晴天彩虹雨17 小时前
存算分离与云原生:数据平台的新基石
大数据·hadoop·云原生·spark
罗不俷18 小时前
【RH134知识点问答题】第13章:运行容器
容器·rhel
春人.21 小时前
PortainerCE 跨云管理:cpolar 内网穿透服务实现多环境统一控制
云原生·eureka