Kubernetes源码学习-Controller-总览篇

K8s源码分析完整系列一键直达:k8s源码笔记-项目地址,若有帮助,欢迎star,谢谢~

Controller源码分段阅读导航

概述

kube-controller的作用

引述

首先依照惯例,贴两篇官方对   于controller的设计逻辑和运行机制的说明文档:

https://github.com/kubernetes/community/blob/master/contributors/devel/sig-api-machinery/controllers.md

https://github.com/kubernetes/community/blob/master/contributors/design-proposals/apps/controller_history.md

Controller是做什么用的?

Controller通过watch apiServer,循环地观察监控着某些特定的资源对象,获取它们当前的状态,对它们进行对比、修正、收敛,来使这些对象的状态不断靠近、直至达成在它们的声明语义中所期望的目标状态,这即是controller的作用。

伪代码

一个简单的controller工作模式的伪代码示例:

for {
  // 期望状态
  desired := getDesiredState()
  // 当前状态
  current := getCurrentState()
  // 使当前状态达到期望状态
  makeChanges(desired, current)
}

kube-controller的组成

kube-controller是一个控制组件,根据我们的使用经验,有多种经常使用的资源,都不是实际地直接进行任务计算的资源类型,而在申明之后由k8s自动发现并保证以达成申明语义状态的逻辑资源,例如deployment、statefulSet、pvc、endpoint等,这些资源都分别由对应的controller子组件,那么这样的controller子组件有多少呢?如下图:

可见controller的组件数量是非常之多的,因此在本部分中计划只抽选其中的deploymentController和statefulSetController这两种常见的对pod管理类型资源对应的controller来进行源码分析。

代码结构

启动入口

kubernetes/src/k8s.io/kubernetes/cmd/kube-controller-manager/controller-manager.go

功能模块

kubernetes/src/k8s.io/kubernetes/pkg/controller

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值