Kubernetes 应用通过 Service Mesh 进行流量切分与灰度发布|学习笔记(二)

简介: 快速学习Kubernetes 应用通过 Service Mesh 进行流量切分与灰度发布

开发者学堂课程【Kubernetes 云原生管理实践】学习笔记,与课程紧密联系,让用户快速学习知识。

课程地址https://developer.aliyun.com/learning/course/751/detail/13222


Kubernetes 应用通过 Service Mesh 进行流量切分与灰度发布


6、整个流程虽然说是轻量级的,但他的想法还是以平台为中心,以集群为中心,OAM 是以应用为中心,这是根本的不同。OSM 项目比较新,它有一个小问题,osm install 这个地方是要上 chart 的,从 github 下载 osm cli,下载之后把它编译,编译之后他就用现在的版本安装 helm chart,这里面会产生一个不一致的情况,github里面的文件可能会比 helm chart 里面的新。所以在编译的时候出现head 的二进制拿到,拿到之后作为 helm chart 里面要下载的 daughter image ID。还有一个地方默认的 service,一些 employ 之间是不能通信的,为了实验方便允许他通信。

 

7、下面从 Injection 开始自动注入 slidecar,主动注入 sildcar 以后就可以往里面添加应用。

image.png

 

之前用了第一版本,这个是第二版本,Containerrizeworkload 的定义放在了一个文件里,使用第二个版本。这个 component 相对是较为简单的,重点是看 trait 怎么定义的?

image.png

 

trait 没有进行代码的封装,所以直接引用,直接使用 API 版本,这样 OAM 就知道该怎么寻找 CRD,最后把信息传送过去。在 demo2 这个应用的定义里面,有两个 component,第一版本和第二版本。

image.png

 

在第二版本里面,要介绍 trait 是怎么定义的 。TrafficSplit 服务有两个版本,它是根据版本。把 Traffic split 全部放在 v1下面,如果不这样做,则默认各一半,所以把它全部放在v1下。

 

8、现在先注册 Components,然后把 trait 也注册上去,今天只需要用到一个 trait。下一步定义应用。

image.png

 

2”的意思是里面有两个容器,第二个容器是 OSM sildcarService也已经有了两个。

image.png

 

Pod 都起来之后,产生一些流量,测试分流这件事情有没有成功。该怎样测试流量呢?流量给 v1 100。现在有个问题,OSM 是以 service employ 来进行流量控制的,我们装的 front-end 只有一个 demployment,没办法使用,必须安装 service 。所以用 port forwarding 比较好。所有的流量都到 v1上,v2上没有,这就是 OSM 进行分流的概念。光标所示地方是v1,如果是 v2,会有显示。

image.png

 

Demo app 本身是往回打标签,hey 工具太快了,所以没看见,现在一个一个打,大家可以看到。

 

9、为什么提倡用 OAM 做这个事情?假设不用 OAM,这个配置文件很常见。

image.png

这个里面有 namematchLabels,然后又是名字。这些内容往后配版本号的时候,很容易出错。为什么 Kubernetes 这样设计?因为这体现了以行为为中心,Kubernetes 是以平台为中心,走不同的 CRD,或者走不同的 Control 都会需要去读一个或者写一个 label,有很多麻烦。如果使用的是以应用为核心的发布方式, 就没有这些事情,只需要关心自己的逻辑。OAM 是绑定这件事的,后面手工要做的事情他已经管理好了,比如现在把这个应用删了,trait也会一起被删掉,不用在管这些事情。以应用为核心,不同团队为分割现代的运维方式简单高效。特别是对于有很多相近的字段的时候,trait 是一个非常好的工具。今天这个 trait 并没有改代码,所以有多种余的字段在里面。如果已经有一个 trait,因为这几个项目是比较新的开源项目,来不及做  trait,是直接套用,所以还是有一些重复的内容。如果是按照 OAM 的定义,定义出来的 trait 会更加精准,更加好用。希望 trait 像应用一样有仓库,需要什么就拿什么。

 

10、为什么 OAM 是一个标准?首先要对 trait 进行管理,如果没有管理,在一个集群当中有哪些 trait 都不知道,现在部署 trait 是没有办法进行管理的,没有办法给用户进行统计,用户没有办法查询。有些 trait 之间是互相抵触的,比如说 KEDA HPA,他之间有可能会出现冲突的情况。假设有一个 trait 的仓库,在进仓库之前,先填好有哪些字段需要维护,有哪些功能,这样就很容易进行管理,而且因为是以应用为中心,所以冗余的字段都不需要,也不会容易产生错误。Component 有两个,一个是第一版本,一个是第二版本,也可以把它分成两个应用。假设有四五个微服务,只有一个为服务有两个版本,还是希望把他们放在一起,作为一个应用。假设把 v1 v2 拆成两个应用,剩下的其他的微服务该怎么办?现在这样做是完全可以的,从业务靠量和出发,这就是 OAM 很多的优点。

相关实践学习
深入解析Docker容器化技术
Docker是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的Linux机器上,也可以实现虚拟化,容器是完全使用沙箱机制,相互之间不会有任何接口。Docker是世界领先的软件容器平台。开发人员利用Docker可以消除协作编码时“在我的机器上可正常工作”的问题。运维人员利用Docker可以在隔离容器中并行运行和管理应用,获得更好的计算密度。企业利用Docker可以构建敏捷的软件交付管道,以更快的速度、更高的安全性和可靠的信誉为Linux和Windows Server应用发布新功能。 在本套课程中,我们将全面的讲解Docker技术栈,从环境安装到容器、镜像操作以及生产环境如何部署开发的微服务应用。本课程由黑马程序员提供。     相关的阿里云产品:容器服务 ACK 容器服务 Kubernetes 版(简称 ACK)提供高性能可伸缩的容器应用管理能力,支持企业级容器化应用的全生命周期管理。整合阿里云虚拟化、存储、网络和安全能力,打造云端最佳容器化应用运行环境。 了解产品详情: https://www.aliyun.com/product/kubernetes
相关文章
|
8月前
|
缓存 Kubernetes Docker
GitLab Runner 全面解析:Kubernetes 环境下的应用
GitLab Runner 是 GitLab CI/CD 的核心组件,负责执行由 `.gitlab-ci.yml` 定义的任务。它支持多种执行方式(如 Shell、Docker、Kubernetes),可在不同环境中运行作业。本文详细介绍了 GitLab Runner 的基本概念、功能特点及使用方法,重点探讨了流水线缓存(以 Python 项目为例)和构建镜像的应用,特别是在 Kubernetes 环境中的配置与优化。通过合理配置缓存和镜像构建,能够显著提升 CI/CD 流水线的效率和可靠性,助力开发团队实现持续集成与交付的目标。
|
8月前
|
存储 监控 对象存储
ACK 容器监控存储全面更新:让您的应用运行更稳定、更透明
针对本地存储和 PVC 这两种容器存储使用方式,我们对 ACK 的容器存储监控功能进行了全新升级。此次更新完善了对集群中不同存储类型的监控能力,不仅对之前已有的监控大盘进行了优化,还针对不同的云存储类型,上线了全新的监控大盘,确保用户能够更好地理解和管理容器业务应用的存储资源。
545 268
|
6月前
|
存储 人工智能 物联网
ACK Gateway with AI Extension:大模型推理的模型灰度实践
本文介绍了如何使用 ACK Gateway with AI Extension 组件在云原生环境中实现大语言模型(LLM)推理服务的灰度发布和流量分发。该组件专为 LLM 推理场景设计,支持四层/七层流量路由,并提供基于模型服务器负载感知的智能负载均衡能力。通过自定义资源(CRD),如 InferencePool 和 InferenceModel,可以灵活配置推理服务的流量策略,包括模型灰度发布和流量镜像。
|
7月前
|
Kubernetes 持续交付 开发工具
阿里云协同万兴科技落地ACK One GitOps方案,全球多机房应用自动化发布,效率提升50%
阿里云协同万兴科技落地ACK One GitOps方案,全球多机房应用自动化发布,效率提升50%
184 2
|
6月前
|
存储 监控 对象存储
ACK 容器监控存储全面更新:让您的应用运行更稳定、更透明
ACK 容器监控存储全面更新:让您的应用运行更稳定、更透明
138 0
ACK 容器监控存储全面更新:让您的应用运行更稳定、更透明
|
7月前
|
存储 监控 对象存储
ACK 容器监控存储全面更新:让您的应用运行更稳定、更透明
ACK 容器监控存储全面更新:让您的应用运行更稳定、更透明
113 1
|
7月前
|
Kubernetes 持续交付 开发工具
阿里云协同万兴科技落地ACK One GitOps方案,全球多机房应用自动化发布,效率提升50%
阿里云协同万兴科技落地ACK One GitOps方案,全球多机房应用自动化发布,效率提升50%
|
8月前
|
存储 监控 对象存储
ACK容器监控存储全面更新:让您的应用运行更稳定、更透明
介绍升级之后的ACK容器监控体系,包括各大盘界面展示和概要介绍。
|
7月前
|
运维 分布式计算 Kubernetes
ACK One多集群Service帮助大批量应用跨集群无缝迁移
ACK One多集群Service可以帮助您,在无需关注服务间的依赖,和最小化迁移风险的前提下,完成跨集群无缝迁移大批量应用。
|
9月前
|
存储 Kubernetes 关系型数据库
阿里云ACK备份中心,K8s集群业务应用数据的一站式灾备方案
本文源自2024云栖大会苏雅诗的演讲,探讨了K8s集群业务为何需要灾备及其重要性。文中强调了集群与业务高可用配置对稳定性的重要性,并指出人为误操作等风险,建议实施周期性和特定情况下的灾备措施。针对容器化业务,提出了灾备的新特性与需求,包括工作负载为核心、云资源信息的备份,以及有状态应用的数据保护。介绍了ACK推出的备份中心解决方案,支持命名空间、标签、资源类型等维度的备份,并具备存储卷数据保护功能,能够满足GitOps流程企业的特定需求。此外,还详细描述了备份中心的使用流程、控制台展示、灾备难点及解决方案等内容,展示了备份中心如何有效应对K8s集群资源和存储卷数据的灾备挑战。

推荐镜像

更多