K8s-金丝雀发布 简单实验

在Kubernetes中,金丝雀发布(Canary Release) 是一种渐进式部署策略,目的是将新版本应用逐步暴露给一小部分用户或流量,通过持续监控确保其稳定性后,再逐步扩大范围直至完全替换旧版本。这种策略的名称来源于"矿井中的金丝雀"------早期矿工用金丝雀来检测有毒气体,如果金丝雀存活,说明环境安全。

金丝雀发布的核心原理

  1. 小范围验证

    • 先部署新版本(金丝雀版本)到生产环境,但仅允许少量用户或流量访问它(例如5%的请求)。

    • 大部分流量仍由旧版本处理,确保用户整体体验不受影响。

  2. 监控与观察

    • 监控新版本的性能指标(如错误率、延迟、CPU/内存使用率等)。

    • 如果新版本表现稳定,逐步增加其流量比例;如果发现问题,立即回滚。

  3. 逐步替换

    • 最终将100%流量切换到新版本,完成平滑升级。

为什么在Kubernetes中使用金丝雀发布?

  1. 降低风险

    • 避免一次性全量发布导致全局故障,尤其适用于关键业务场景。
  2. 快速反馈

    • 通过真实流量验证新版本,比测试环境更可靠。
  3. 无缝回滚

    • 发现问题时,只需将流量切回旧版本,无需重新部署。

创建条件是让蓝绿在同一个service名称下

vim green.yml

|kubectl apply -f green.yml

vim blue.yml

kubectl apply -f blue.yml

kubectl get po

查看服务端口kubectl get svc

完成后可以在网页上访问 192.168.11.160:32016

之后可以通过命令更改蓝绿的pod数量

kubectl scale deployment myapp-blue --replicas 8

kubectl scale deployment myapp-green --replicas 2

通过ingress做

vim blue.yml

kubectl apply -f blue.yml

vim green.yml

kubectl apply -f green.yml

vim green-svc.yml

kubectl apply -f green-svc.yml

vim ingress-canary.yml

kubectl apply -f ingress-canary.yml

vim master-ingress.yml

kubectl apply -f master-ingress.yml

kubectl get ingress 两个ingress共用一个地址

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

在node节点添加 vim /etc/hosts

修改`canary-weight`注解值,逐步增加新版本流量:(也可以在文件中修改)

kubectl annotate ingress/myapp-canary \

nginx.ingress.kubernetes.io/canary-weight="50" \ # 50%流量到v2

--overwrite

相关推荐
m0_737539371 小时前
kuberntes Config
云原生·容器·kubernetes
DO_Community1 小时前
AI 成本太高怎么办?用推理路由自动分配 Claude、Qwen、DeepSeek
云原生·serverless·aigc·claude·deepseek
程序员老舅2 小时前
Linux:谁把根目录卸载了?
linux·c++·容器·linux内核·文件系统·根目录
cnskylee2 小时前
【Kubernetes】使用kubeadm安装三节点K8s集群遇到的问题总结
云原生·容器·kubernetes
容器魔方2 小时前
Kthena Router ScorePlugin 架构与基准测试分析
人工智能·云原生·容器·架构·开源
眷蓝天2 小时前
Kubernetes Helm 包管理详解
云原生·容器·kubernetes
吴声子夜歌3 小时前
Java——通用容器类
java·容器
叶~小兮3 小时前
K8S优先级、Pod驱逐、HPA扩缩容 学习笔记
笔记·学习·kubernetes
xingfujie3 小时前
第2章:服务器规划与基础环境配置
linux·运维·微服务·云原生·容器·kubernetes·负载均衡