k8s中,通过代码生成工具生成的controller中加入控制逻辑

摘自http://www.infoq.com/cn/articles/kubernetes-status-management-and-extension

前文自动生成的代码中为Bee生成了默认的BeeController,如图1.2.2所示。

当监听到创建或更新Bee状态的时候,可以通过实现Reconcile中的逻辑来处理对Bee的额外扩展,现在来把Controller部署到集群中去。

将前面写入的Bee全部删除后重新写入,可以看到Controller打印了两条日志分别为写入的Bee.Name,如图1.2.3所示。

此处提到的Reconcile接口只能响应存在状态修改的场景,是一种无状态的扩展模式,如果需要响应删除,可以利用后文介绍的Informer接口来实现,此处不赘述,只给一个简单例子(如图1.2.4)。有趣的是,BeeController部署到集群里面,没有进行额外配置就可以连接到对应的APIServer正常运转了,它是如何自动与前文部署的API Server建立连接呢?这在后文“API聚合层”中会具体介绍,此处亦不赘述。

注意删除了前面写入的v1alpha1.Bee和v1alpha2.Bee两个版本的Bee,但实际上BeeController是利用v1alpha1客户端监听Bee的删除事件,显然v1alpha1的Informer也可以感知到所有版本Bee的变化,这其实就是兼容性设计的美妙之处了,不赘述。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值