06|client-go进阶玩法之RestMapper
邢云阳

你好,我是邢云阳。
在上一节课中,我们探讨了通过自然语言操控 Kubernetes 的基本原理,并分析了为了提升系统的可用性和安全性所需考虑的一些关键设计点,例如如何有效地使用 client-go。针对用户可能对任意 Kubernetes 资源进行操作的需求,我们引入了通用化的处理方案 RestMapper。同时,为了缓解查询操作对 apiserver 的访问压力,我们还提出了 Informer 方法。
在本节课中,我将重点介绍 RestMapper 的概念与应用。
为了照顾到对 client-go 不是太熟悉的同学,我们先从基础入手,讲解一下 client-go 四种客户端的使用手法以及 GVR、GVK 等概念。
四种客户端
在 client-go 中,有四种可以与 Kubernetes 资源进行交互的客户端,分别是 ClientSet、DynamicClient、DiscoveryClient 以及 RestClient,它们各自适用于不同的场景。下面结合代码来体会一下。
ClientSet
ClientSet 是最常用的客户端,用于与 Kubernetes 核心资源(如 Pod、Service、Deployment 等)进行交互。它封装了对各类资源的操作,提供了类型安全的接口。我们用一个列出 default 命名空间下的 pod 列表的例子,看一下代码如何实现。
公开
同步至部落
取消
完成
0/2000
笔记
复制
AI
- 深入了解
- 翻译
- 解释
- 总结

1. Client-go中有四种可以与Kubernetes资源进行交互的客户端,分别是ClientSet、DynamicClient、DiscoveryClient和RestClient,它们各自适用于不同的场景。 2. ClientSet是最常用的客户端,用于与Kubernetes核心资源进行交互,提供了类型安全的接口。 3. DynamicClient适用于操作未知类型的自定义资源(CRD),不需要强类型定义,通过动态结构处理任意资源。 4. RestClient直接通过url来访问资源,类似于RestAPI,通常用于使用聚合API技术自定义API后进行调用。 5. DiscoveryClient用于发现Kubernetes集群支持的GVR,常用于获取Kubernetes集群支持的API组和版本信息. 6. RestMapper是一个工具,用于解析和确定Kubernetes资源的元数据信息,包括资源类型到API Group/Version的映射和确定资源的操作方式。 7. RestMapper的返回值叫做RestMapping,包含了资源的详细信息,如Group、Version、Kind、Scope、Resource和Path。 8. RestMapper可以帮助从资源名称推导出完整的GVR信息,使得与Kubernetes资源的交互更加通用化。 9. 通过RestMapper工具,可以实现Resource到GVR的映射,进而使用动态客户端来操作Kubernetes资源。 10. 修炼好内功,才能让我们做出更好的AI产品。
仅可试看部分内容,如需阅读全部内容,请付费购买文章所属专栏
《AI 重塑云原生应用开发实战》,新⼈⾸单¥59
《AI 重塑云原生应用开发实战》,新⼈⾸单¥59
立即购买
© 版权归极客邦科技所有,未经许可不得传播售卖。 页面已增加防盗追踪,如有侵权极客邦将依法追究其法律责任。
登录 后留言
精选留言
由作者筛选后的优质留言将会公开显示,欢迎踊跃留言。
收起评论