带你读《云原生应用开发 Operator原理与实践》第二章 Operator 原理2.2Client-go 原理(八)

本文涉及的产品
容器服务 Serverless 版 ACK Serverless,317元额度 多规格
容器服务 Serverless 版 ACK Serverless,952元额度 多规格
简介: 带你读《云原生应用开发 Operator原理与实践》第二章 Operator 原理2.2Client-go 原理

2.2.3         Client-go架构

Client-go主要用在 Kubernetes控制器中,包括内置控制器kube-controller-manager)CRD控制器,Client-go架构如图 2-6所示。根据图 2-6介绍 Client-go的几个组件。

image.png


2—6Cient—go架构

 

(1)  Reflector:使用 List-Watch 的方法监控指定类型的资源对象,从 KubernetesAPIServerList该资源的所有实例,取得最新的ResourceVersion,然后使用 Watch方法监听该 resourceVersion之后的所有变化,若过程中出现异常,Reflector则会从断开的ResourceVersion处重现尝试监听所有变化,一旦该对象的实例有创建、删除、更新动作,Reflector  都会收到“事件通知,并利用反射机制将监听的结果实例化成具体的对象。这时,该事件及它对应的实例对象的组合称为增量Delta,之后会被存进 DeltaFIFO中。

(2) DeltaFIFO:作为一个增量队列,将 Reflector监控变化的对象形成一个 FIFO列,此处的 Delta就是变化。

(3) LocalStore:Informer会不断地从 DeltaFIFO中读取增量,每出现一个对象,Informer就会判断这个增量的事件类型,然后创建或更新本地缓存,也就是 LocalStore。例如,如果事件类型是 Added(添加对象,那么 Informer 会把这个增量中的对象保存到本地缓存中,并为它创建索引;若为删除操作,则在本地缓存中删除该对象。此外,LocalStore   还利用索引提供快速查找的能力,当使用者需要查询(Get/List)Kubernetes对象时,可以直接请求 LocalStore,以此减轻 KubernetesAPIServer的压力。

(4) WorkqueueDeltaFIFO在同步完LocalStore后,会Pop这个事件到ControllerController会调用事先注册的 ResourceEventHandler回调函数OnAdd、OnUpdateOnDelete)进行处理,这些回调函数只做一些简单的过滤工作,最后将变更对象放Workqueue中,供 Worker中的业务逻辑处理。

(5) Clients:Client-go中的各类客户端,当 Worker中业务逻辑要操作 Kubernetes资源时,可以通过客户端实现。


2.2.4       Discovery原理

在分析 Discovery原理之前,首先介绍一下Kubernetes的资源模型,图 2-7是获取所有 Deployements资源的 RESTfulAPI,URL 中各字段含义如下。

(1)      appsGroup 资源组,包含一组资源操作的集合。

(2)      v1Version资源版本,用于区分不同 API 的稳定程度及兼容性。

(3)      DeploymentsResource 资源信息,用于区分不同的资源 API。

image.png


图 2—7Depioyments 资原 URL

 

由于历史原因,Kubernetes中有两种资源组:有组名资源组和无组名资源组(也叫核心资源组,CoreGroups)。上面介绍的就是有组名资源组,而Pods、Services等资源属于无组名资源组,图 2-8是获取 Pods资源的 RESTfulAPI,其中未包含Group信息,但拥VersionResource信息。

image.png


2—8Pods资原 URL

 

常用的 Kubectl命令,当执行 kubectlapi-versionskubectlapi-resources命令时,返回的就是GVR(Group,Version,Resource)信息(见代码清单2-29

$kubectlapi-versionsadmissionregistration.k8s.io/v1admissionregistration.k8s.io/v1beta1apiextensions.k8s.io/v1apiextensions.k8s.io/v1beta1apiregistration.k8s.io/v1apiregistration.k8s.io/v1beta1apps/v1

...

 

$ kubectl

api-resources

 

NAME

SHORTNAMES

APIGROUP

NAMESPACED    KIND

bindings

 

 

true       Binding

componentstatuses          cs               falseComponentStatus

configmaps                cm                                  true

ConfigMap

 

endpoints

ep

true

Endpoints

events

ev

true

Event

...

 

 

 

相关实践学习
通过Ingress进行灰度发布
本场景您将运行一个简单的应用,部署一个新的应用用于新的发布,并通过Ingress能力实现灰度发布。
容器应用与集群管理
欢迎来到《容器应用与集群管理》课程,本课程是“云原生容器Clouder认证“系列中的第二阶段。课程将向您介绍与容器集群相关的概念和技术,这些概念和技术可以帮助您了解阿里云容器服务ACK/ACK Serverless的使用。同时,本课程也会向您介绍可以采取的工具、方法和可操作步骤,以帮助您了解如何基于容器服务ACK Serverless构建和管理企业级应用。 学习完本课程后,您将能够: 掌握容器集群、容器编排的基本概念 掌握Kubernetes的基础概念及核心思想 掌握阿里云容器服务ACK/ACK Serverless概念及使用方法 基于容器服务ACK Serverless搭建和管理企业级网站应用
相关文章
|
18天前
|
Kubernetes Cloud Native 持续交付
云原生技术在现代应用开发中的角色与实践
【9月更文挑战第9天】 随着云计算技术的飞速发展,云原生(Cloud Native)已经成为推动企业数字化转型的核心力量。本文将深入探讨云原生的基本概念、关键技术及其在实际开发中的应用案例,旨在为读者提供一条清晰的云原生技术学习路径和应用指南。通过实例分析,我们将揭示云原生如何优化资源管理、提升应用性能及加快部署速度,进而帮助企业构建更加灵活、可靠和高效的软件系统。
|
4天前
|
设计模式 Cloud Native API
云原生时代的微服务架构实践
【9月更文挑战第23天】在这篇文章中,我们将深入探讨云原生环境下的微服务架构设计原则、优势以及实施策略。文章不仅涉及理论概念,还结合具体的代码示例,帮助读者理解如何在实际项目中应用微服务架构。通过阅读本文,你将获得构建、部署和管理微服务的实用知识,为你的云原生项目奠定坚实的基础。
|
5天前
|
运维 Kubernetes Cloud Native
云原生技术在现代企业中的应用与实践
【9月更文挑战第22天】 在数字化浪潮的推动下,云原生技术已经成为企业IT架构转型的重要方向。本文将深入探讨云原生技术的核心概念、优势以及如何在企业中实施云原生策略。我们将从容器化技术的基本原理出发,逐步引导读者理解服务网格和微服务架构的设计思路,并通过实际案例分析,展示云原生技术如何助力企业实现敏捷开发和高效运维。文章旨在为技术人员提供云原生实践的参考,并启发企业决策者对于云原生转型的深度思考。
|
2天前
|
Cloud Native 持续交付 Docker
云原生技术入门与实践:Docker容器化部署示例
【9月更文挑战第25天】在数字化转型的浪潮下,云原生技术成为推动企业创新的重要力量。本文旨在通过浅显易懂的语言,为初学者揭示云原生技术的核心概念及其应用价值。我们将以Docker容器为例,逐步引导读者了解如何将应用程序容器化,并在云端高效运行。这不仅是对技术趋势的跟随,更是对资源利用和开发效率提升的探索。
12 4
|
4天前
|
Kubernetes Cloud Native 持续交付
云原生技术在现代应用开发中的实践与思考
【9月更文挑战第23天】本文将深入探讨云原生技术如何革新现代应用的开发流程。通过分析云原生的核心概念、优势以及实际应用案例,我们旨在揭示这一新兴技术范式如何助力开发者和企业更高效、灵活地构建和部署应用程序。文章还将提供具体代码示例,展示云原生技术在实际项目中的应用,帮助读者更好地理解和掌握该技术。
|
5天前
|
Cloud Native 持续交付 开发者
云原生技术在现代应用开发中的应用与实践
【9月更文挑战第22天】本文将深入探讨云原生技术如何革新现代应用开发,通过实际案例分析其对提高开发效率、促进持续集成与交付的显著影响。我们将从云原生的基本概念出发,逐步展开到容器化、微服务架构、自动化管理的实践操作,以及这些技术如何协同工作以支持复杂应用的快速迭代和扩展。文章旨在为开发者提供一套云原生技术的实践框架,帮助他们构建更加灵活、可维护的应用系统。
|
7天前
|
Kubernetes Cloud Native Serverless
探索云原生技术:从基础架构到应用实践
本文深入探讨了云原生技术的各个方面,包括其定义、核心原则、关键技术组件以及在现代企业中的应用。通过分析云原生如何推动数字化转型和提高业务敏捷性,文章旨在为读者提供对这一领域的全面了解和实际应用的指导。
33 7
|
5天前
|
Kubernetes Cloud Native 云计算
云原生技术入门与实践
【9月更文挑战第22天】本文将带你了解云原生技术,并探讨如何利用它来构建高效、可扩展的应用。我们将从基础概念开始,逐步深入到实际应用,最后通过一个简单的示例展示如何在Kubernetes上部署一个容器化应用。无论你是初学者还是有经验的开发者,这篇文章都将为你提供宝贵的见解和实用的技巧。
|
15天前
|
Cloud Native 持续交付 云计算
云原生技术在现代应用开发中的应用与实践
【9月更文挑战第12天】随着云计算技术的飞速发展,云原生已成为推动企业数字化转型的关键技术之一。本文将深入探讨云原生的基本概念、核心价值及其在现代应用开发中的实际应用案例,旨在为读者提供一套清晰的云原生应用开发指南。通过分析容器化、微服务架构、持续部署等核心技术的实践过程,我们将揭示云原生如何助力开发者高效构建、部署和管理可扩展的应用。你将看到代码示例,这些示例均选自真实世界的开发场景,帮助你理解云原生技术的强大功能和灵活性。
|
15天前
|
运维 Cloud Native Devops
云原生架构的崛起与实践云原生架构是一种通过容器化、微服务和DevOps等技术手段,帮助应用系统实现敏捷部署、弹性扩展和高效运维的技术理念。本文将探讨云原生的概念、核心技术以及其在企业中的应用实践,揭示云原生如何成为现代软件开发和运营的主流方式。##
云原生架构是现代IT领域的一场革命,它依托于容器化、微服务和DevOps等核心技术,旨在解决传统架构在应对复杂业务需求时的不足。通过采用云原生方法,企业可以实现敏捷部署、弹性扩展和高效运维,从而大幅提升开发效率和系统可靠性。本文详细阐述了云原生的核心概念、主要技术和实际应用案例,并探讨了企业在实施云原生过程中的挑战与解决方案。无论是正在转型的传统企业,还是寻求创新的互联网企业,云原生都提供了一条实现高效能、高灵活性和高可靠性的技术路径。 ##
24 3

热门文章

最新文章