K8s-蓝绿发布 简单实验

蓝绿发布

在Kubernetes中,蓝绿发布(Blue-Green Deployment) 是一种部署策略,通过同时维护两个完全独立的生产环境("蓝"和"绿"),在验证新版本(绿)后,一次性将流量从旧版本(蓝)切换到新版本,若发现问题则立即回退。其核心特点是零停机时间快速回滚

蓝绿发布的核心原理

  1. 双环境共存

    • 蓝环境(Blue):当前生产环境,处理所有用户流量。

    • 绿环境(Green):新版本环境,部署完成后处于待命状态。

  2. 流量切换

    • 通过更新负载均衡规则或Service选择器,将所有流量从蓝环境切换到绿环境。
  3. 快速回滚

    • 若绿环境异常,只需将流量重新指向蓝环境即可恢复。

蓝绿发布的实现方法及步骤

通过Service切换标签

原理:利用Kubernetes Service的标签选择器,将流量从旧版本Pod(蓝)切换到新版本Pod(绿)

部署蓝环境 vim blue.yml

kubectl apply -f blue.yml

创建绿环境vim green.yml

kubectl apply -f green.yml

查看绑定端口:kubectl get svc

验证:192.168.11.160:32118

更改service匹配标签:kubectl patch service myapp-service -p '{"spec":{"selector":{"version":"green"}}}'

写一个ingress :vim ingress.yml

kubectl apply -f ingress.yml

kubectl get ingress

修改 Nginx 网关的对外端口(Service)配置,LoadBalancer改为NotePort

kubectl -n ingress-nginx edit svc ingress-nginx-controller

查看服务kubectl -n ingress-nginx get po -owide 运行在哪个节点

查看端口号kubectl -n ingress-nginx get svc

在node2节点 vim /etc/hosts 添加

curl green.jx.com:31426 , curl blue.jx.com:31426​​​​​​​

相关推荐
运维老郭1 小时前
【K8S调度避坑指南】5类调度策略硬核拆解:nodeSelector不够用?亲和性、污点与容忍度生产级实战
运维·云原生·kubernetes
xingfujie1 小时前
前言:从零到一,系统掌握 K8s + DevOps + 微服务
linux·运维·微服务·云原生·容器·kubernetes·devops
亚空间仓鼠1 小时前
Docker容器化高可用架构部署方案(九)
docker·容器·架构
AOwhisky1 小时前
Docker 学习笔记:Docker Compose 多容器编排
linux·运维·笔记·学习·docker·容器
China_Yanhy2 小时前
【云原生 AI 实战】EKS 搭建 GPU 超算集群:从零拉起节点到 PyTorchJob 分布式训练 (附 EFA 加速避坑指南)
人工智能·分布式·云原生
Devin~Y2 小时前
电商AIGC智能客服面试:JVM调优、Spring Cloud微服务、Redis缓存、Kafka消息、K8s观测与RAG落地
java·jvm·spring boot·redis·spring cloud·kafka·kubernetes
炸炸鱼.2 小时前
从入门到实战:Kubernetes完全指南——概念、架构、集群部署与Dashboard可视化
容器·架构·kubernetes
爱学习 爱分享11 小时前
k8s 开启防火墙,容器内部无法访问外部 ip
tcp/ip·容器·kubernetes
叶帆11 小时前
【YFIOs】Docker方式部署
运维·docker·容器