【大话云原生】kubernetes灰度发布篇-从步行到坐缆车的自动化服务升级

举报
字母哥哥 发表于 2022/04/14 00:27:11 2022/04/14
【摘要】 看过很多关于云原生的文章,要么云山雾罩,要么曲高和寡。 所以笔者就有了写《大话云原生》系列文章的想法,期望用最通俗、简单的语言、方便记忆的场景来说明:云原生生态系统内的组成及应用关系。 ...

看过很多关于云原生的文章,要么云山雾罩,要么曲高和寡。 所以笔者就有了写《大话云原生》系列文章的想法,期望用最通俗、简单的语言、方便记忆的场景来说明:云原生生态系统内的组成及应用关系。

一、Kubernetes的Pod概念解析

说到老婆过生日了我们一起出去旅游,上了团体服务班车,小娜同学(老婆)闲聊到:“这服务还不错哈,2个跟车导游,1个司机”。三句不离老本行,我无聊的说到:“他们三个人就是一个Pod,提供一天的旅游服务内容,有主有次不可分割"。

Kubernets的Pod概念解析
小娜同学又上套了:“什么是Pod啊?英文单词豌豆荚?”,让老婆增加对老公崇拜感的机会不可多得,那就开讲,反正坐车也是闲着。

  • 一般来说一个Pod提供一种服务(微服务),“哎?之前说容器技术的时候你也是这么说的”。是的,容器是提供服务的最小单元,那么Pod是什么概念?这是因为我们现在讨论的是k8s,Pod是k8s服务调度的最小单元
  • “为什么引入Pod的概念?”,因为有的时候你会发现:一个服务通常包含辅助它的服务。比如这个车上,一个导游长得漂亮口才好作为主导游提供核心讲解服务,还有一个辅助她的导游负责发帽子、统计人数、统计消费等。同理回到架构技术角度举个例子:一个nginx提供web服务容器作为核心服务容器,负责收集nginx日志的服务容器作为辅助服务和它部署在一个Pod,这样方便日志收集与网络连接。
  • 一个Pod存在一个基础容器Infra,基础容器Infra提供了网络共享的能力,就像主导游和辅助导游必须在一辆车(基础容器Infra)上,或者基于这辆车组成了一个组合,否则他们之间无法对话及资源共享。
  • 一个Pod下的容器共享网络及数据卷,所以将容器服务间具有相当强的捆绑关系的服务容器放到一个Pod里面,通常一个容器提供核心服务,其他的容器提供辅助服务,如:日志收集、监控告警等。

二、Pod标签与Service服务

聊着聊着很快车就到了旅游目的地,一下车发现X公司的团队还真不少。导游都统一都带上了深红色的帽子(游客带上蓝色遮阳帽),浩浩荡荡出发。深红色的帽子为导游Pod服务打上了标签,他们面向游客(用户)提供了统一的一种服务叫做:“导游服务”。

Pod标签与Service服务

对于K8s中的服务架构也是一样的:

  • 一个Pod通常提供一种服务,如nginx web访问服务
  • 多个提供同样服务的Pod通常打上一样的标签
  • 创建Service:具备同一种标签的Pod组成一个Service,对外提供服务。

三、自动化服务升级-灰度发布

我们今天的项目是爬山,提供了两种上山的方式:一是直接爬(即步行),二是坐缆车,当然如果你中途爬不动了也可以在缆车换乘站上缆车。

  • “步行服务”到“缆车服务”可以理解为一次服务升级(1.0版本服务升级为2.0版本服务)。从技术角度,一次服务升级等同于新版本服务的上线部署被称为一次Deployment。K8s同样使用Deployment这个术语代表服务升级部署。
  • ReplicaSet代表一个版本的Pod服务组合,1.0为步行版本的Pod服务组合,2.0为缆车版本的Pod服务组合,这样理解是不是容易多了呢?
  • 在服务容器部署Deployment的过程中,我们不希望面向用户的服务中断(即:不希望对步行1.0的用户的服务出现中断情况),所以停掉一个1.0的Pod,再启动一个2.0的Pod2.0,这个过程被称为灰度发布。整个过程高度依赖Kubernetes提供的自动化运维能力。

自动化服务升级-灰度发布

上面的图每个RS只有2个Pod,还不能那么直观的理解灰度发布,看下面这张图

  • 圆形代表Pod,分为v1版本和v2版本,虚线标识的Pod表示即将下线的Pod
  • v1版本的Pod减一,v2版本的pod加一
  • 逐渐ReplicaSet:v1的Pod全部销毁,ReplicaSet:v2的Pod逐渐被创建并启动提供服务
  • 整个的灰度发布过程,在k8s中通过一个Deployment进行定义并执行。

自动化服务升级-灰度发布2

文章来源: zimug.blog.csdn.net,作者:字母哥哥,版权归原作者所有,如需转载,请联系作者。

原文链接:zimug.blog.csdn.net/article/details/124054775

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。