k8s client-go快速入门教程及源代码阅读之Scheme编解码
本文主要讲解k8s源码中基于Scheme
的编解码机制, Scheme
就像一个类型大管家,内部注册了各种GVK
, 所以使用静态客户端的时候,我们才能无感的直接得到静态类型的指定对象,而不是像动态客户端得到一个Unstructured
。
本文主要讲解k8s源码中基于Scheme
的编解码机制, Scheme
就像一个类型大管家,内部注册了各种GVK
, 所以使用静态客户端的时候,我们才能无感的直接得到静态类型的指定对象,而不是像动态客户端得到一个Unstructured
。
golang的net/http包同时支持客户端和服务端,而本文主要分析客户端的代码,通过查看源代码可以更好的理解net/http的使用,也能好好的学习一下golang官方的代码风格。
之前无论是讲解静态客户端还是动态客户端都可以略过了client-go底层的RESTClient的构造过程,这篇文章主要分析RESTClient的构造和请求过程,k8s的API都遵循RESTFul规范,所以客户端自然可以以对应的约定形式构造,所以叫做RESTClient。
与client-go静态客户端相对应的自然就是动态客户端了,动态客户端的价值在于灵活,不用重新生成客户端代码就能访问k8s集群中的所有资源,即使是非内置资源。
client-go的客户端可以分为两类,一类称为静态客户端,另一类称为动态客户端,前者的好处在接口已经固定,在写代码的时候有很好的提示,坏处是无法访问非k8s内置资源,后者的好处是够灵活,但是需要使用者知道GVK/GVR等前置知识。两者各有好处,需要根据自己需要选择。
从上一篇文章,我们知道使用client-go操作k8s的资源基本分为三步,1. 配置加载,2. 创建客户端,3. 使用接口,这一篇文章主要专注于使用client-go时的配置加载, 而配置加载,主要是加载认证和连接信息。
client-go是kubernetes官方维护的一个go语言客户端,用于与k8s集群交互,使用client-go可以很方便的完成k8s的二次开发(似乎也必不可少),无论是稳定性还是健壮性都有充分的保障。
golang内置了非常多优秀的库,net/http
是其中之一,net/http
不只是一个http客户端,它还实现了服务端,鉴于它非常贴心的设计,基于net/http
做一个web server是一件非常容易的事情,但是本文主要聚焦于http客户端相关的功能。
几乎所有程序都是可以配置的,这些配置信息一般以配置文件的方式存在,各编程语言有自己的配置管理方案,而Golang的一个非常流行和强大的配置管理库是viper
, 是cobra
作者写来跟cobra
一起配合使用而编写的。
cobra
也许是go语言现有最好的命令行框架了,在各大项目中皆有使用,比如最出名的kubernetes
, 所以要写一个稍微复杂的命令行工具,使用cobra还是不错的,cobra
内置了非常多有用的功能,包括但不限于,自动生成帮助文档, 生成命令行代码的脚手架工具, 智能提示等等。