蓝绿发布
在Kubernetes中,蓝绿发布(Blue-Green Deployment) 是一种部署策略,通过同时维护两个完全独立的生产环境("蓝"和"绿"),在验证新版本(绿)后,一次性将流量从旧版本(蓝)切换到新版本,若发现问题则立即回退。其核心特点是零停机时间 和快速回滚。
蓝绿发布的核心原理
-
双环境共存:
-
蓝环境(Blue):当前生产环境,处理所有用户流量。
-
绿环境(Green):新版本环境,部署完成后处于待命状态。
-
-
流量切换:
- 通过更新负载均衡规则或Service选择器,将所有流量从蓝环境切换到绿环境。
-
快速回滚:
- 若绿环境异常,只需将流量重新指向蓝环境即可恢复。
蓝绿发布的实现方法及步骤
通过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
