【原创】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


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

 

1.2 GroupMeta

我们再看下groupmeta的保存

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

groupmeta保持的group的metadata信息

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

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

 接下来就是保存group的信息

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

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

1.3 Scheme

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

api下注册了很多types


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

v1下注册了很多的types

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

1.4 注册

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


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


从上面的init函数来看,先注册了“”的一个group信息,然后初始化了 GroupVersiongroupVersion, Group:apiutil.GetGroup(groupVersion) , Version:apiutil.GetVersion(groupVersion), Codec:runtime.CodecFor(api.Scheme, groupVersion), groupMeta.Versions = versions groupMeta.GroupVersions = groupVersions groupMeta.SelfLinker = runtime.SelfLinker(accessor)   在之后 NewDefaultRESTMapper
【原创】k8s源码分析-----kubectl(1)api.RESTMapper_第7张图片

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

2、DefaultRESTMapper

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

 

 
我们看看结构体


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


3、功能

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

 

查找version版本

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

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

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

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


  

4、总结

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

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

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

 

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

 

 

 

龚浩华

QQ 月牙寂 29185807

2016年4月18日

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

你可能感兴趣的:(源码,开源,golang,容器,k8s)