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​​​​​​​

相关推荐
阿里云云原生20 小时前
AI 开发新常态:当 Cursor、Claude、Codex 并行,如何统一管理散落的 Skill 资产?
云原生·ai编程
探索云原生1 天前
K8s 1.36 这个 GA 特性,把 initContainer 拉模型的 hack 干掉了
ai·云原生·kubernetes
云恒要逆袭1 天前
运行你的第一个Docker容器
后端·docker·容器
Java之美1 天前
从edge-trigger到level-trigger,谈谈 Kubernetes controller 的开发范式
云原生
阿里云云原生2 天前
深度解构:当 Append-only 的 SLS 遇上 Update/Delete,是如何实现设计权衡的?
云原生
Java之美2 天前
一次k8s升级引发的DevicePlugin注册失败
云原生·kubernetes
秋播2 天前
nerdctl推送rancher本地镜像到harbor
云原生
程序员老赵3 天前
10 分钟部署 OpenCode:Docker 一键安装,浏览器打开就能用 AI 写代码(附完整命令与排错)
docker·容器·ai编程
阿里云云原生3 天前
告别冗长链路!Kafka × Table Bucket 实现开放表格式零 ETL 实时入湖
云原生·kafka