【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/ ,切换不一样的版本。

相关推荐
catoop24 分钟前
K8s 无头服务(Headless Service)
云原生·容器·kubernetes
阿里嘎多学长41 分钟前
docker怎么部署高斯数据库
运维·数据库·docker·容器
小峰编程1 小时前
独一无二,万字详谈——Linux之文件管理
linux·运维·服务器·云原生·云计算·ai原生
小马爱打代码2 小时前
云原生服务网格Istio实战
云原生
G_whang2 小时前
windos 安装docker
运维·docker·容器
道一云黑板报2 小时前
Flink集群批作业实践:七析BI批作业执行
大数据·分布式·数据分析·flink·kubernetes
运维小文3 小时前
K8S中的PV、PVC介绍和使用
docker·云原生·容器·kubernetes·存储
ζั͡山 ั͡有扶苏 ั͡✾3 小时前
Kubeadm+Containerd部署k8s(v1.28.2)集群(非高可用版)
云原生·容器·kubernetes
Hadoop_Liang3 小时前
Kubernetes ConfigMap的创建与使用
云原生·容器·kubernetes
老猿讲编程4 小时前
技术发展历程:从 CORBA 到微服务
微服务·云原生·架构