您当前的位置:首页 > 电脑百科 > 程序开发 > 编程百科

一文读懂Kubernetes部署策略

时间:2024-01-03 14:19:35  来源:今日头条  作者:架构成长指南

在这篇文章中,我们将深入研究 Kube.NETes 部署概念和一些常见策略,了解每种策略的优缺点。合适的部署策略使我们能够在发布应用程序时最大限度地减少停机时间、增强客户体验并提高可靠性。

什么是 Kubernetes 部署策略?

Kubernetes 部署是一种声明性语句,通常在 YAML 文件中配置,用于定义应用程序生命周期以及如何管理对该应用程序的更新。

当将应用程序部署到 K8s 集群时,所选择的部署策略将决定如何将应用程序从旧版本更新到新版本。某些策略可能会导致停机时间,而其他策略则可能引入测试概念并允许用户分析。本文将介绍两种常用的基本 K8s 部署策略:

  • 重新创建(Recreating)
  • 滚动更新(Rolling)

以下策略被认为是“高级部署策略”,因为可以以多种方式控制流量的流向:

  • 蓝/绿(Blue/Green)
  • 金丝雀(Canary)
  • A/B
  • 影子部署(Shadow Deployment)

K8s 使用滚动更新策略作为默认策略,但在某些情况下可能不适用。让我们详细讨论每种策略!

1. 重新创建部署(Recreate Deployment)

重新创建部署会终止所有的 Pod,并用新版本的 Pod 替换它们。这在旧版本和新版本的应用程序不能同时运行的情况下很有用。使用此策略产生的停机时间取决于应用程序关闭和启动所需的时间。由于完全替换,应用程序状态也会完全更新。

示例如下,type=Recreate表示为重新创建

spec:
  replicas: 10
  strategy:
    type: Recreate

一文读懂Kubernetes部署策略

一文读懂Kubernetes部署策略

2. 滚动更新部署(Rolling Deployment)

滚动更新是 K8s 的默认部署方式,旨在减少集群的停机时间。滚动更新会将运行旧版本应用程序的 Pod 逐步替换为新版本,而无需停机。

一文读懂Kubernetes部署策略

为了实现这一点,要使用就绪探针(Readiness probes)

就绪探针监视应用程序何时变为可用状态。如果探针失败,流量将不会发送到该 Pod。这些探针用于需要在就绪之前执行部分初始化步骤的应用程序,比如数据库链接、缓存数据初始化,应用的发布注册等操作。

一旦就绪探针检测到新版本应用程序可用,旧版本应用程序将被删除。如果出现问题,可以停止部署并回滚到上一个版本,避免整个集群的停机时间。由于每个 Pod 逐个替换,对于较大的集群,部署需要一定的时间。如果在另一个部署完成之前触发了新的部署,版本将更新为新部署中指定的版本,并且尚未部署成功的先前部署版本将被忽略。

触发滚动更新部署的条件是 Pod 规范中的某些更改,例如更新 Pod 的镜像、环境变量或标签。可以使用命令 kubectl set image 来更新 Pod 镜像。

yaml文件的 Spec: -> strategy: 部分可以使用两个参数来细化部署:maxSurge 和 maxUnavailable。这两个参数可以指定为百分比或绝对数值。当使用水平 Pod 自动缩放时,应使用百分比。

  • maxSurge 指定部署允许同时创建的最大 Pod 数量。
  • maxUnavailable 指定在部署期间允许不可用的最大 Pod 数量。

例如,下面的配置要求有 10 个副本,最多同时创建 3 个副本,允许在部署期间有 1 个副本不可用:

spec:
  replicas: 10
  strategy:
    type: RollingUpdate
    rollingUpdate:
      maxSurge: 3
      maxUnavailable: 1

3.蓝/绿部署(Blue/Green Deployment)

蓝/绿部署涉及将新的应用程序版本(绿色)与旧版本(蓝色)一起部署。通过服务选择器对象作为负载均衡器,当新应用程序(绿色)经过测试和验证后,将流量引导到新应用程序而不是旧应用程序。蓝/绿部署可能会造成成本增加,因为在部署期间需要启动两倍数量的应用程序资源。

一文读懂Kubernetes部署策略

为了实现这一点,我们需要设置一个在部署之前的服务。例如,对于名为 web-App 的应用程序的 v1.0.0 版本的蓝色部署,yaml 文件中的服务选择器部分可能如下所示:

kind: Service
metadata:
 name: web-app-01
 labels:
   app: web-app
selector:
   app: web-app
   version: v1.0.0

蓝色 web-app 的部署如下:

kind: Deployment
metadata:
  name: web-app-01
spec:
  template:
        metadata:
           labels:
             app: web-app
             version: "v1.0.0"

当我们想要将流量引导到应用程序的新(绿色)版本时,我们更新 manifest 文件以指向新版本 v2.0.0。

kind: Service
metadata:
 name: web-app-02
 labels:
   app: web-app
selector:
   app: web-app
   version: v2.0.0

绿色应用程序的部署如下:

kind: Deployment
metadata:
  name: web-app-02
spec:
  template:
        metadata:
           labels:
             app: web-app
             version: "v2.0.0"

4. 影子部署(Shadow Deployment)

金丝雀与“影子部署”一词可以互换使用。

影子部署是一种策略,其中新版本的应用程序与现有的生产版本一起部署,主要用于监控和测试目的。在影子部署中,用户流量不会主动路由到新版本。这对于测试新功能的生产负载特别有用。

一文读懂Kubernetes部署策略

这种技术比较复杂,需要特殊要求,尤其是出口流量。例如,有一个商品,您想调用支付服务进行影子测试,最终可能会让客户为他们的订单支付两次,所以复杂性比较高

5. 金丝雀部署(Canary Deployments)

金丝雀部署可用于让一部分用户测试应用程序的新版本,或者在对新版本的功能性没有完全信心时使用。新版本的一个副本与旧版本一起发布,其中旧版本应用程序为大部分用户提供服务,而新版本应用程序为一小部分测试用户提供服务。如果新部署成功,则将其逐渐扩展到更多用户。

一文读懂Kubernetes部署策略

例如,在一个具有 100 个运行的 Pod 的 K8s 集群中,有 95 个运行着应用程序的 v1.0.0 版本,而有 5 个运行着新的 v2.0.0 版本。95% 的用户将被路由到旧版本,而5% 的用户将被路由到新版本。为此,我们使用并行的两个部署,可以分别进行扩展。

旧应用程序的 yaml 文件中的 spec 部分可能如下所示:

spec:
  replicas: 95

新应用程序的 yaml 文件中的 spec 部分可能如下所示:

spec:
  replicas: 5

在上面的示例中,运行 100 个 Pod 可能是不切实际的。更好的方法是使用负载均衡器,如Nginx、HAProxy或Traefik,或者使用类似Istio、Hashicorp Consul或Linkrd的服务网格,他们可以提供对流量的更好控制。

6. A/B 部署

与金丝雀部署类似,使用 A/B 部署,我们可以基于一些目标参数(通常是 HTTP 标头或 cookie等)定位给定的用户,并根据权重在不同版本之间分配流量。这种技术被广泛用于测试某个特定功能的转化率,然后选择转化率最高的版本进行最终部署。

一文读懂Kubernetes部署策略

这种方法通常基于收集的用户行为数据,并用于做出更好的业务决策。在 A/B 测试期间,用户通常不会被告知新功能,以便进行真实的测试,并可以比较使用旧版本和新版本的用户之间的体验。由于额外的测试期和用户体验分析,使用 A/B 部署进行部署速度可能会较慢。

可以使用 Istio 和 Flagger 自动化进行 A/B 部署。

总结

在本文中,我们讨论了6种常见的K8s部署策略。在决定如何部署或升级您的应用程序时,如何使用这些策略,以及使用哪些工具来实现每种策略是非常重要的。



Tags:Kubernetes   点击:()  评论:()
声明:本站部分内容及图片来自互联网,转载是出于传递更多信息之目的,内容观点仅代表作者本人,不构成投资建议。投资者据此操作,风险自担。如有任何标注错误或版权侵犯请与我们联系,我们将及时更正、删除。
▌相关推荐
Kubernetes 究竟有没有 LTS?
从一个有趣的问题引出很多人都在关注的 Kubernetes LTS 的问题。有趣的问题2019 年,一个名为 apiserver LoopbackClient Server cert expired after 1 year[1] 的 issue 中提...【详细内容】
2024-03-15  Search: Kubernetes  点击:(5)  评论:(0)  加入收藏
Kubernetes 集群 CPU 使用率只有 13% :这下大家该知道如何省钱了
作者 | THE STACK译者 | 刘雅梦策划 | Tina根据 CAST AI 对 4000 个 Kubernetes 集群的分析,Kubernetes 集群通常只使用 13% 的 CPU 和平均 20% 的内存,这表明存在严重的过度...【详细内容】
2024-03-08  Search: Kubernetes  点击:(12)  评论:(0)  加入收藏
聊聊 Kubernetes 网络模型综合指南
这篇详细的博文探讨了 Kubernetes 网络的复杂性,提供了关于如何在容器化环境中确保高效和安全通信的见解。译自Navigating the Network: A Comprehensive Guide to Kubernete...【详细内容】
2024-02-19  Search: Kubernetes  点击:(37)  评论:(0)  加入收藏
Kubernetes是什么?主要特点是什么?
Kubernetes是什么?Kubernetes,也称为K8s,是一个开源的容器编排系统,由Google首次开发和维护。它允许容器化的应用程序在集群中自动部署、扩展和管理。Kubernetes提供了一种容器...【详细内容】
2024-02-01  Search: Kubernetes  点击:(153)  评论:(0)  加入收藏
开发者的Kubernetes懒人指南
你可以将本文作为开发者快速了解 Kubernetes 的指南。从基础知识到更高级的主题,如 Helm Chart,以及所有这些如何影响你作为开发者。译自Kubernetes for Lazy Developers。作...【详细内容】
2024-02-01  Search: Kubernetes  点击:(50)  评论:(0)  加入收藏
Kubernetes Informer基本原理,你明白了吗?
本文分析 k8s controller 中 informer 启动的基本流程不论是 k8s 自身组件,还是自己编写 controller,都需要通过 apiserver 监听 etcd 事件来完成自己的控制循环逻辑。如何高...【详细内容】
2024-01-30  Search: Kubernetes  点击:(37)  评论:(0)  加入收藏
Kubernetes 100个常用命令!
这篇文章是关于使用 Kubectl 进行 Kubernetes 诊断的指南。列出了 100 个 Kubectl 命令,这些命令对于诊断 Kubernetes 集群中的问题非常有用。这些问题包括但不限于:• 集...【详细内容】
2024-01-03  Search: Kubernetes  点击:(76)  评论:(0)  加入收藏
一文读懂Kubernetes部署策略
在这篇文章中,我们将深入研究 Kubernetes 部署概念和一些常见策略,了解每种策略的优缺点。合适的部署策略使我们能够在发布应用程序时最大限度地减少停机时间、增强客户体验并...【详细内容】
2024-01-03  Search: Kubernetes  点击:(58)  评论:(0)  加入收藏
从Kubernetes的探针到DevOps
今天在群里又看有人问如何设置 Kubernetes 的探针,感觉要补充的话太多了,结合我们在一些 DevOps 项目中痛苦的体验,今天一劳永逸的全部说完,此外,也为大家展现一下为什么 DevOps...【详细内容】
2023-12-27  Search: Kubernetes  点击:(113)  评论:(0)  加入收藏
如何基于Kubernetes运行Nacos高可用集群
Nacos(Namings and Configuration Management)是阿里巴巴开源的一个易于构建云原生应用的动态服务发现、配置管理和服务管理平台。以下是Nacos的一些主要功能和特点: 服务发现...【详细内容】
2023-12-18  Search: Kubernetes  点击:(68)  评论:(0)  加入收藏
▌简易百科推荐
即将过时的 5 种软件开发技能!
作者 | Eran Yahav编译 | 言征出品 | 51CTO技术栈(微信号:blog51cto) 时至今日,AI编码工具已经进化到足够强大了吗?这未必好回答,但从2023 年 Stack Overflow 上的调查数据来看,44%...【详细内容】
2024-04-03    51CTO  Tags:软件开发   点击:(5)  评论:(0)  加入收藏
跳转链接代码怎么写?
在网页开发中,跳转链接是一项常见的功能。然而,对于非技术人员来说,编写跳转链接代码可能会显得有些困难。不用担心!我们可以借助外链平台来简化操作,即使没有编程经验,也能轻松实...【详细内容】
2024-03-27  蓝色天纪    Tags:跳转链接   点击:(12)  评论:(0)  加入收藏
中台亡了,问题到底出在哪里?
曾几何时,中台一度被当做“变革灵药”,嫁接在“前台作战单元”和“后台资源部门”之间,实现企业各业务线的“打通”和全域业务能力集成,提高开发和服务效率。但在中台如火如荼之...【详细内容】
2024-03-27  dbaplus社群    Tags:中台   点击:(8)  评论:(0)  加入收藏
员工写了个比删库更可怕的Bug!
想必大家都听说过删库跑路吧,我之前一直把它当一个段子来看。可万万没想到,就在昨天,我们公司的某位员工,竟然写了一个比删库更可怕的 Bug!给大家分享一下(不是公开处刑),希望朋友们...【详细内容】
2024-03-26  dbaplus社群    Tags:Bug   点击:(5)  评论:(0)  加入收藏
我们一起聊聊什么是正向代理和反向代理
从字面意思上看,代理就是代替处理的意思,一个对象有能力代替另一个对象处理某一件事。代理,这个词在我们的日常生活中也不陌生,比如在购物、旅游等场景中,我们经常会委托别人代替...【详细内容】
2024-03-26  萤火架构  微信公众号  Tags:正向代理   点击:(10)  评论:(0)  加入收藏
看一遍就理解:IO模型详解
前言大家好,我是程序员田螺。今天我们一起来学习IO模型。在本文开始前呢,先问问大家几个问题哈~什么是IO呢?什么是阻塞非阻塞IO?什么是同步异步IO?什么是IO多路复用?select/epoll...【详细内容】
2024-03-26  捡田螺的小男孩  微信公众号  Tags:IO模型   点击:(8)  评论:(0)  加入收藏
为什么都说 HashMap 是线程不安全的?
做Java开发的人,应该都用过 HashMap 这种集合。今天就和大家来聊聊,为什么 HashMap 是线程不安全的。1.HashMap 数据结构简单来说,HashMap 基于哈希表实现。它使用键的哈希码来...【详细内容】
2024-03-22  Java技术指北  微信公众号  Tags:HashMap   点击:(11)  评论:(0)  加入收藏
如何从头开始编写LoRA代码,这有一份教程
选自 lightning.ai作者:Sebastian Raschka机器之心编译编辑:陈萍作者表示:在各种有效的 LLM 微调方法中,LoRA 仍然是他的首选。LoRA(Low-Rank Adaptation)作为一种用于微调 LLM(大...【详细内容】
2024-03-21  机器之心Pro    Tags:LoRA   点击:(12)  评论:(0)  加入收藏
这样搭建日志中心,传统的ELK就扔了吧!
最近客户有个新需求,就是想查看网站的访问情况。由于网站没有做google的统计和百度的统计,所以访问情况,只能通过日志查看,通过脚本的形式给客户导出也不太实际,给客户写个简单的...【详细内容】
2024-03-20  dbaplus社群    Tags:日志   点击:(4)  评论:(0)  加入收藏
Kubernetes 究竟有没有 LTS?
从一个有趣的问题引出很多人都在关注的 Kubernetes LTS 的问题。有趣的问题2019 年,一个名为 apiserver LoopbackClient Server cert expired after 1 year[1] 的 issue 中提...【详细内容】
2024-03-15  云原生散修  微信公众号  Tags:Kubernetes   点击:(5)  评论:(0)  加入收藏
站内最新
站内热门
站内头条