【原创】k8s源码分析-----kubectl(1)api.RESTMapper

 

本文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,但并没有系统的讲解。那么这一章,我们先系统的讲解下

 

1、构建

源码在k8s.io\kubernetes\pkg\api\mapper.go

【原创】k8s源码分析-----kubectl(1)api.RESTMapper_第1张图片

声明了一个全局变量RESTMapper,并在init函数中初始化了

 

那么什么时候注册呢?

在之前,我们需要看看,group/version 是一个很重要的东西

1.1 版本号注册

我们先看下版本号的注册

 

代码在k8s.io\kubernetes\pkg\api\registered

【原创】k8s源码分析-----kubectl(1)api.RESTMapper_第2张图片

先读取了环境变量KUBE_API_VERSIONS,一般来说这个设置为空,那就是默认的为"v1,extensions/v1beta1"

 

1.2 GroupMeta

我们再看下groupmeta的保存

代码在k8s.io\kubernetes\pkg\api\latest

groupmeta保持的group的metadata信息

【原创】k8s源码分析-----kubectl(1)api.RESTMapper_第3张图片

【原创】k8s源码分析-----kubectl(1)api.RESTMapper_第4张图片

 接下来就是保存group的信息

【原创】k8s源码分析-----kubectl(1)api.RESTMapper_第5张图片

上面有一个函数,用来注册group

1.3 Scheme

代码在k8s.io\kubernetes\pkg\api\register.go

api下注册了很多types

【原创】k8s源码分析-----kubectl(1)api.RESTMapper_第6张图片

k8s.io\kubernetes\pkg\api\v1\register.go

v1下注册了很多的types

【原创】k8s源码分析-----kubectl(1)api.RESTMapper_第7张图片

1.4 注册

代码在k8s.io\kubernetes\pkg\api\install

【原创】k8s源码分析-----kubectl(1)api.RESTMapper_第8张图片

【原创】k8s源码分析-----kubectl(1)api.RESTMapper_第9张图片

 

从上面的init函数来看,先注册了“”的一个group信息,然后初始化了GroupVersiongroupVersion,Group:apiutil.GetGroup(groupVersion),Version:apiutil.GetVersion(groupVersion),Codec:runtime.CodecFor(api.Scheme, groupVersion),groupMeta.Versions = versionsgroupMeta.GroupVersions = groupVersionsgroupMeta.SelfLinker = runtime.SelfLinker(accessor) 在之后NewDefaultRESTMapper

【原创】k8s源码分析-----kubectl(1)api.RESTMapper_第10张图片

 

 
 遍历了所有注册在Scheme的类型,ignoredKinds类型将直接跳过,这里我们要注意两个rootScoped对应的是meta.RESTScopeRoot,其余的对应的是meta.RESTScopeNamespace

2、DefaultRESTMapper

下面我们来分析下RESTMapper的作用代码在k8s.io\kubernetes\pkg\api\meta\restmapper.go在上面mapper调用了meta.NewDefaultRESTMapper

【原创】k8s源码分析-----kubectl(1)api.RESTMapper_第11张图片
 
 我们看看结构体

【原创】k8s源码分析-----kubectl(1)api.RESTMapper_第12张图片

 其实从结构体来看,就是保存了一个mapping。这个是这个结构的最主要东西 根据上面构建的流程,最后调用了Add

【原创】k8s源码分析-----kubectl(1)api.RESTMapper_第13张图片

 

3、功能

那么最后就是mapper的提供的功能了

 【原创】k8s源码分析-----kubectl(1)api.RESTMapper_第14张图片

查找version版本

【原创】k8s源码分析-----kubectl(1)api.RESTMapper_第15张图片

根据version和kind查找相关的信息

【原创】k8s源码分析-----kubectl(1)api.RESTMapper_第16张图片

最后返回一个结构体,主要的就是相对应的kind包含的所有信息

【原创】k8s源码分析-----kubectl(1)api.RESTMapper_第17张图片

  

4、总结

首先,注册所有的version版本,用于版本管理。

然后注册了所有的group版本,用于group管理

最后,针对group和version注册了RESTMapper。

 

RESTMapper用于管理所有对象的信息。外部要获取的话,直接通过version,group获取到RESTMapper,然后通过kind类型可以获取到相对应的信息

 

 

 

龚浩华

QQ 月牙寂 道长 29185807

2016年4月18日

 (版权声明:本文为作者原创,如需转载请通知本人,并标明出处和作者。擅自转载的,保留追究其侵权的权利。)

 

如果你觉得本文对你有帮助,可以转到你的朋友圈,让更多人一起学习。

第一时间获取文章,可以关注本人公众号:月牙寂道长,也可以扫码关注

 

 

你可能感兴趣的:(容器云,容器,golang,分布式)