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

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

2. 使用说明

 

操作 Kubernetes集群的方式有多种,但本质上都要通过调用KubernetesRESTAPI实现对集群的访问和操作。例如,常用的Kubectl命令,当执行 KubectlGetPods命令时,KubectlKubernetesAPIServer完成认证,并发送 GET请求(见代码清单2-7

GET/api/v1/namespaces/test/pods

---

200OK

Content-Type:application/json

{

"kind":"PodList",

"apiVersion":"v1","metadata":{...},

"items":[...]

}

 

Client-go库抽象封装了与 KubernetesRESTAPI的交互,方便开发者对Kubernetes的二次开发。利用 Client-go操作 Kubernetes资源的流程基本如下。

(1)  通过 KubeConfig信息,构造 Config 实例。该实例记录了集群证书、KubernetesAPIServer地址等信息。

(2)  根据 Config实例携带的信息,构建特定客户端(例如,ClientSetDynamicSet

(3)  利用客户端向 KubernetesAPIServer发起请求,操纵 Kubernetes资源。

下面以Examples目录中的示例讲解Client-go库的使用流程(见代码清单2-8

示例:out-of-cluster-client-configuration,列出 defaultNamespace下所有的 Pod资源。

funcmain(){

varkubeconfig*string

ifhome:=homeDir();home!=""{

kubeconfig=flag.String("kubeconfig",

filepath.Join(home,".kube","config"),"(optional)absolutepathtothekubeconfigfile",

)

}else{

kubeconfig=flag.String("kubeconfig","","absolutepathtothekubeconfigfile")

}

flag.Parse()

 

//usethecurrentcontextinkubeconfig

config,err:=clientcmd.BuildConfigFromFlags("",*kubeconfig)

iferr!=nil{

panic(err.Error())

}

 

//createtheclientset

clientset,err:=kubernetes.NewForConfig(config)

iferr!=nil{

panic(err.Error())

}

for{

pods,err:=clientset.CoreV1().Pods("").List(context.TODO(),metav1.

ListOptions{})

iferr!=nil{

panic(err.Error())

}

 

//...

}

}

 

funchomeDir()string{

if h:=os.Getenv("HOME");h!=""{returnh

}

returnos.Getenv("USERPROFILE")//windows


}

 

(1)加载配置信息

在访问 Kubernetes集群时,需要进行身份认证。Kubeconfig用于管理访问集群的配置信息,默认的Kubeconfig文件路径为 $HOME/.kube/config。范例中通过命令行参数配置,若存在HOME环境变量,则使用默认 Kubeconfig配置,并利用 BuildConfig-FromFlags函数构建 Config结构体。

(2)构建客户端

在操作资源前需要先构建对应客户端(具体客户端种类在后面章节介绍,示例中利用NewForConfig函数构建 ClientSet,ClientSet能访问 Kubernetes自身内置的资源,这里ClientSet负责列出 Pod 资源。

(3)操作资源

根据 Kubernetes 资源类型和版本的不同,ClientSet 中包含了一组操作资源的客户端,如代码清单 2-9所示,操作Pod资源使用 CoreV1客户端。示例中:CoreV1方法返回对应客户端;Pods方法指定要操作的对象是 Pod资源,参数用于设定 Namespace为空,表defaultNamespace;List方法表示对资源的操作动作,有 ListGetCreateDelete等。最终返回的Pods 变量就包含了所有Pod 资源的信息。

typeClientsetstruct{

*discovery.DiscoveryClient

//...

coreV1                     *corev1.CoreV1Client

 

//...

}

//...

 

//CoreV1retrievestheCoreV1Client

func(c*Clientset)CoreV1()corev1.CoreV1Interface{returnc.coreV1

}

 

以上只是简单介绍了 ClientSet的使用流程,下面将详细讲解Client-go中所有客户端的功能原理及使用方式。

相关实践学习
通过Ingress进行灰度发布
本场景您将运行一个简单的应用,部署一个新的应用用于新的发布,并通过Ingress能力实现灰度发布。
容器应用与集群管理
欢迎来到《容器应用与集群管理》课程,本课程是“云原生容器Clouder认证“系列中的第二阶段。课程将向您介绍与容器集群相关的概念和技术,这些概念和技术可以帮助您了解阿里云容器服务ACK/ACK Serverless的使用。同时,本课程也会向您介绍可以采取的工具、方法和可操作步骤,以帮助您了解如何基于容器服务ACK Serverless构建和管理企业级应用。 学习完本课程后,您将能够: 掌握容器集群、容器编排的基本概念 掌握Kubernetes的基础概念及核心思想 掌握阿里云容器服务ACK/ACK Serverless概念及使用方法 基于容器服务ACK Serverless搭建和管理企业级网站应用
相关文章
|
1月前
|
Kubernetes Cloud Native 安全
云原生架构的演进与实践
随着云计算技术的不断发展,云原生架构已成为现代软件开发的核心趋势。本文旨在探讨云原生架构的演变历程、核心理念及在实际项目中的应用案例。通过对Kubernetes、Docker等关键技术的分析,结合微服务架构的设计原则,本文将揭示如何构建高效、可扩展且易于维护的云原生应用。
50 10
|
19天前
|
Cloud Native 持续交付 开发者
云原生技术在现代企业中的应用与实践####
本文深入探讨了云原生技术的核心概念及其在现代企业IT架构转型中的关键作用,通过具体案例分析展示了云原生如何促进企业的敏捷开发、高效运维及成本优化。不同于传统摘要仅概述内容,本部分旨在激发读者对云原生领域的兴趣,强调其在加速数字化转型过程中的不可或缺性,为后续详细论述奠定基础。 ####
|
9天前
|
Cloud Native 安全 Java
铭师堂的云原生升级实践
铭师堂完整经历了云计算应用的四个关键阶段:从”启动上云”到”全量上云”,再到”全栈用云”,最终达到”精益用云”。通过 MSE 云原生网关的落地,为我们的组织带来了诸多收益,SLA 提升至100%,财务成本降低67%,算力成本降低75%,每次请求 RT 减少5ms。
铭师堂的云原生升级实践
|
1月前
|
运维 Kubernetes Cloud Native
云原生技术入门及实践
【10月更文挑战第39天】在数字化浪潮的推动下,云原生技术应运而生,它不仅仅是一种技术趋势,更是企业数字化转型的关键。本文将带你走进云原生的世界,从基础概念到实际操作,一步步揭示云原生的魅力和价值。通过实例分析,我们将深入探讨如何利用云原生技术提升业务灵活性、降低成本并加速创新。无论你是云原生技术的初学者还是希望深化理解的开发者,这篇文章都将为你提供宝贵的知识和启示。
|
8天前
|
Cloud Native
邀您参加云原生高可用技术沙龙丨云上高可用体系构建:从理论到实践
云原生高可用技术专场,邀您从理论到实践一起交流,探索云上高可用体系构建!
|
8天前
|
Cloud Native 安全 Java
杭州铭师堂的云原生升级实践
在短短 2-3 年间,杭州铭师堂完整经历了云计算应用的四个关键阶段:从“启动上云”到“全量上云”,再到“全栈用云”,最终达到“精益用云”。也从云计算的第一次浪潮,迈过了第二次浪潮,顺利的进入到了 第三次浪潮 AI + 云。
|
19天前
|
Kubernetes Cloud Native API
云原生入门:从理论到实践的探索之旅
本文旨在为初学者提供一个关于云原生技术的全面介绍,包括其定义、核心原则、关键技术组件以及如何将这些概念应用于实际项目中。我们将通过一个简易的代码示例,展示如何在云原生环境下部署一个简单的应用,从而帮助读者更好地理解云原生技术的实践意义和应用价值。
|
21天前
|
运维 Cloud Native 开发者
云原生技术入门与实践
在云计算的浪潮中,云原生技术以其独特的优势和魅力吸引了越来越多的开发者和企业。本文将从云原生技术的基本概念、核心组件以及实际应用三个方面进行详细介绍,帮助读者更好地理解和掌握这一新兴技术。同时,文章还将分享一些实际案例和经验教训,让读者能够更深入地了解云原生技术的应用场景和发展趋势。
36 5
|
28天前
|
Kubernetes Cloud Native 微服务
云原生入门与实践:Kubernetes的简易部署
云原生技术正改变着现代应用的开发和部署方式。本文将引导你了解云原生的基础概念,并重点介绍如何使用Kubernetes进行容器编排。我们将通过一个简易的示例来展示如何快速启动一个Kubernetes集群,并在其上运行一个简单的应用。无论你是云原生新手还是希望扩展现有知识,本文都将为你提供实用的信息和启发性的见解。
|
1月前
|
监控 Cloud Native 持续交付
云原生技术在现代企业中的应用与实践
本文将深入探讨云原生技术如何改变现代企业的运作模式,提升业务灵活性和创新能力。通过实际案例分析,我们将揭示云原生架构的关键要素、实施步骤以及面临的挑战,为读者提供一套清晰的云原生转型指南。