Kubernetes -3-ios
[TOC]git
本日状态:github
帮同事排了一天bug。api
Kubernetes -3-学习
这是yann的第98篇分享spa
第 1 部分 承前调试
昨天用视屏的方式演示了构建 Deployment 的过程,并探讨了 crd 的流程和实现过程。从本篇开始就逐步实现这个过程,yann 保证你们都能完成一次 crd 的开发经历。code
第 2 部分 项目orm
咱们先看一下官方的实例程序。cdn
网址以下:
https://github.com/kubernetes/sample-controller
CRD的官方的示例程序仍是很规整的,中规中矩。若是学习Go语言的话,用相似的示例作出发点仍是很好的,比选择我的一时兴趣建立的工程或者某个网页上随便找的Hello World要好不少。
不少同窗不喜欢看官方的示例程序,认为又臭又长,内容复杂,版本还老。喜欢我的博客里面简化介绍,一条线结束,操做几下结果就出来了。平心而论,yann 也不喜欢看。可是为了认知的准确性,会勉强本身看。
从上面的截图来看, 官方示例仍是略微复杂了一点。咱们从零开始建立一个更简化的项目。
仍是先建立一个 crd.yaml,注意内容和文件路径,有些值等会用到。
位置:github.com/kubernetes/yann-controller/artifacts/examples/crd.yaml
apiVersion: apiextensions.k8s.io/v1beta1kind: CustomResourceDefinitionmetadata:name: tests.yanncontroller.k8s.iospec:group: yanncontroller.k8s.ioversion: v1alpha1names: kind: Test plural: testsscope: Namespaced复制代码
在第一篇中咱们说到的 apiVersion、kind、 metadata、spec 等几个固定的字段全员出现了。相似的状况在 k8s 中大量存在,因此咱们只关注有变化部分就行了。
此次要关注的是 tests 和 yanncontroller ,分别为类型名的复数和分组名。在 metadata 里面能够看到。
另外注意,定义成类型的 Test,首字母T是大写的。
最后 yann 带你们补全代码生成的所有文件。在本篇中,yann只会给你们展现基本的文件结构,代码具体内容和每一个文件的用途,会在后面的篇章中逐渐说明。
咱们只要看 pkg 目录下的文件就好。该目录包含2个子目录 apis、signals ,这两个目录是固定不变的,分别表明了 api 和信号量 相关的文件。
而 apis 下面的目录及子目录是本身定义的,分别对应 crd.yaml 配置文件中的分组名前缀 yanncontroller 和spec 定义的版本号 v1alpha1。
除了这2个目录外,其余文件的名字都是固定不变的。这样分析下来,应该好理解不少。
第 3 部分 总结
今天的内容并非不少, 可是侧重理解。搞清楚 crd.yaml 中字段和构建工程的关系是重中之重。了解以后就会发现没什么难度了。
下一篇,会开始解析各个文件的内容,同时为官方示例构建环境。
交互操做是一个很好的作法, 经过构建好的环境编译执行官方示例,能够加深对项目的了解。
同时,有一个正确的环境,对本身建立项目的调试颇有帮助。若是项目和环境都没法保证正确,排查难度会倍增。
本文由博客一文多发平台 OpenWrite 发布!
发布在平台的文章, 和原文存在格式差别, 阅读不便请见谅
最新内容欢迎关注公众号: