标签:
本文QQ空间链接:http://user.qzone.qq.com/29185807/blog/1460961715
本文csdn博文链接:http://blog.csdn.net/screscent/article/details/51179485
源码为k8s v1.1.1稳定版本
api. RESTMapper是kube-apiserver和kubectl的基础,在讲解kube-apiserver的时候,我们就有简单的讲解api. RESTMapper,但并没有系统的讲解。那么这一章,我们先系统的讲解下
源码在k8s.io\kubernetes\pkg\api\mapper.go
声明了一个全局变量RESTMapper,并在init函数中初始化了
那么什么时候注册呢?
在之前,我们需要看看,group/version 是一个很重要的东西
我们先看下版本号的注册
代码在k8s.io\kubernetes\pkg\api\registered
先读取了环境变量KUBE_API_VERSIONS,一般来说这个设置为空,那就是默认的为"v1,extensions/v1beta1"
我们再看下groupmeta的保存
代码在k8s.io\kubernetes\pkg\api\latest
groupmeta保持的group的metadata信息
接下来就是保存group的信息
上面有一个函数,用来注册group
代码在k8s.io\kubernetes\pkg\api\register.go
api下注册了很多types
k8s.io\kubernetes\pkg\api\v1\register.go
v1下注册了很多的types
代码在k8s.io\kubernetes\pkg\api\install
那么最后就是mapper的提供的功能了
查找version版本
根据version和kind查找相关的信息
最后返回一个结构体,主要的就是相对应的kind包含的所有信息
首先,注册所有的version版本,用于版本管理。
然后注册了所有的group版本,用于group管理
最后,针对group和version注册了RESTMapper。
RESTMapper用于管理所有对象的信息。外部要获取的话,直接通过version,group获取到RESTMapper,然后通过kind类型可以获取到相对应的信息
龚浩华
QQ 月牙寂 29185807
2016年4月18日
【原创】k8s源码分析-----kubectl(1)api.RESTMapper
标签:
原文地址:http://blog.csdn.net/screscent/article/details/51179485