-
接下来详细讲述应用的编码过程,如果您不想自己写代码,也可以在 GitHub 下载完整的应用源码,地址和链接信息如下表所示:
![](https://i-blog.csdnimg.cn/blog_migrate/bef9e39585f4b7e66c48d964807f625b.png)
-
这个 git 项目中有多个文件夹,本章源码在 k8s_customize_controller 这个文件夹下,如下图红框所示:
-
为什么要做 controller
-
但如果仅仅是在 etcd 保存 Student 对象是没有什么意义的,试想通过 deployment 创建 pod 时,如果只在 etcd 创建 pod 对象,而不去 node 节点创建容器,那这个 pod 对象只是一条数据而已,没有什么实质性作用,其他对象如 service、pv 也是如此; controller 的作用就是监听指定对象的新增、删除、修改等变化,针对这些变化做出相应的响应(例如新增 pod 的响应为创建 docker 容器),关于 controller 的详细设计,最好的参考就是 Harry (Lei) Zhang 老师在 twitter 上的分享,如下图,地址是: https://twitter.com/resouer/status/1009996649832185856
-
如上图,API 对象的变化会通过 Informer 存入队列(WorkQueue),在 Controller 中消费队列的数据做出响应,响应相关的具体代码就是我们要做的真正业务逻辑;
自动生成代码是什么
-
从上图可以发现整个逻辑还是比较复杂的,为了简化我们的自定义 controller 开发,k8s 的大师们利用自动代码生成工具将 controller 之外的事情都做好了,我们只要专注于 controller 的开发就好。
-
关于 controller 的代码我们留待下一章完成,本章关注的是如何自动生成代码的实战,将上图中 controller 之外的事情都完成了;
开始实战
-
接下来要做的事情就是编写 API 对象 Student 相关的声明的定义代码,然后用代码生成工具结合这些代码,自动生成 Client、Informet、WorkQueue 相关的代码;
-
在 $GOPATH/src/目录下创建一个文件夹 k8s_customize_controller :
-
进入文件夹 k8s_customize_controller,执行如下命令创建三层目录: