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

相关推荐
G皮T1 小时前
【Kubernetes】K8s 的鉴权管理(二):基于属性 / 节点 / Webhook 的访问控制
kubernetes·k8s·鉴权·rbac·webhook·访问控制·abac
Eliauk &2 小时前
【docker】通过云服务器安转Docker
java·运维·服务器·spring cloud·docker·容器
ly14356786192 小时前
92、K8s之ingress下集
云原生·容器·kubernetes
晚妍2 小时前
Kubernetes (k8s)v1.27.1版本安装步骤
云原生·容器·kubernetes
Flying_Fish_roe3 小时前
Kubernetes 与 springboot集成
spring boot·容器·kubernetes
一直奔跑在路上5 小时前
【kubernetes】Ingress和Ingress-Controller介绍,高可用应用案例
云原生·容器·kubernetes
摇曳的精灵5 小时前
单机docker-compose部署minio
运维·docker·容器·文件·minio·compose
Hai9902186 小时前
ingress对外服务
容器·kubernetes
Q行天下6 小时前
x86的Docker环境下载ARM版容器镜像
arm开发·docker·容器
无休居士8 小时前
你天天用微服务还不知道心跳检测机制是什么?
微服务·zookeeper·云原生·eureka·架构·etcd·consul