Kubernetes 官方文档
  • 前言
  • 词汇表
  • 概念
    • 概述
      • 组件
      • 对象
        • 理解 Kubernetes 对象
        • 管理 Kubernetes 对象
        • 对象名称和 ID
        • 标签(Label)和选择算符(Selector)
        • 命名空间(Namespace)
        • 注解(Annotation)
        • 字段选择器
        • Finalizers
        • 属主与附属
    • 架构
      • 节点
    • 工作负载
      • 工作负载资源
        • Job
    • 服务、负载均衡和网络
      • 服务
        • 服务定义
        • 无头服务(Headless Service)
        • 发布服务
    • 配置
      • 配置最佳实践
    • 策略
      • 资源配额
    • 调度、抢占和驱逐
      • Kubernetes 调度器
    • 集群管理
      • 证书
      • 管理资源
        • 组织资源配置
        • kubectl 中的批量操作
        • 有效地使用标签
        • 金丝雀部署
        • 更新标签
      • 集群网络系统
  • 任务
    • 管理集群
      • 手动生成证书
    • 运行应用
      • Pod 水平自动扩缩容
        • HPA 是如何工作的?
      • HPA 演练
        • 创建 HPA
        • 附录
    • TLS
      • 管理集群中的 TLS 认证
  • 参考
    • API 访问控制
      • 使用 RBAC 鉴权
        • API 对象
        • 默认 Roles 和 Role Bindings
        • 初始化与预防权限提升
        • 命令行工具
        • ServiceAccount 权限
        • EndpointSlices 和 Endpoints 写权限
        • 从 ABAC 升级
    • 组件工具
      • kube-scheduler
    • 调度
      • 调度器配置
      • 调度策略
    • 网络参数
      • Service 所用的协议
      • 虚拟 IP 和服务代理
    • 命令行工具 (kubectl)
  • 博客
    • 移除 Dockershim 的常见问题
由 GitBook 提供支持
在本页

这有帮助吗?

在GitHub上编辑
  1. 概念
  2. 集群管理
  3. 管理资源

金丝雀部署

另一个需要多标签的场景,是用来区分同一组件的不同版本或不同配置的多个部署。常见的做法是部署一个金丝雀发布来部署新应用版本(在 Pod 模板中通过镜像标签指定),操持新旧版本应用同时在线。这样,新版本在完全发布之前也可以接收实时的生产流量。

假如,使用 track 标签来区分不同的版本。主要稳定的发行版的标签是 track: stable:

     name: frontend
     replicas: 3
     ...
     labels:
        app: guestbook
        tier: frontend
        track: stable
     ...
     image: gb-frontend:v3

然后,创建一个新版本,让标签设置为 track: canary,以便两组 Pod 不会重复:

     name: frontend-canary
     replicas: 1
     ...
     labels:
        app: guestbook
        tier: frontend
        track: canary
     ...
     image: gb-frontend:v4

Service 通过筛选标签的公共子集(即忽略 track 标签)来覆盖两组副本,以便流量可以转发到两个应用上:

    selector:
      app: guestbook
      tier: frontend

可以调整 stable 和 canary 版本的副本数量,以确定每个版本将接收实时生产流量的比例(本例为 3:1)。一旦新版本验证通过,可以将新版本应用的 track 标签的值从 canary 替换为 stable,此时会覆盖老版本 Pod,即删除老版本应用。

上一页有效地使用标签下一页更新标签

最后更新于2年前

这有帮助吗?

想要了解更多的具体示例,请查看 。

Ghost 部署教程