K8S的架构

k8s 整体采用的是主从架构 master 和 worker node

maser:集群大脑负责管理,调度,控制

worker node: 运行实际业务员容器的节点

maser 又分为以下组件

  1. api-service :所有才做都通过它实现,与etcd 交互 。同时提供watch 监控
  2. etcd :数据库,记录存储所有数据,状态
  3. kube-scheduler:负责pod调度,绑定node
  4. controller-manage: 控制器循环,维持节点期望状态

总结

apiservice 负责操作etcd ,etcd 负责记录数据变化,sechdule 查询etcd 并负责绑定pod和node,controller-manger 循环监控各个pod的状态,如果与预期不符就删除,重建pod。这个给流程采用的是观察者模式,各个组件之间完全解耦。

疑问

为什么 apiservice 调用etcd 还说 2个是解耦?

因为他们之间没有强依赖,哪天不想用etcd了,换成mysql 一样是不需要动apiservice的 。就像springData 你用mysql或是mongo 都没有影响。

这种是典型的适配器模式。

apiservice 还用到了外观模式:不管scheduler 还是 controller 都只是调用 apiservice, 不用关系api的实现【权限校验,写入etcd】等。

注意

etcd 生产部署的时候一定要和master 分开,至少是隔离开。最好独占SSD 硬盘

watch

k8s 架构的核心 ,http实现的长链接

controller ,scheduler,kubelet 都向apiservice发起 watch请求,建立了长链接

bash 复制代码
1. scheduler / controller / kubelet
   向 apiserver 发起 WATCH 请求(长连接)

2. apiserver 接收,保持连接不断开

3. apiserver 内部监听 etcd 变化

4. 一旦 etcd 数据变了
   apiserver 立刻把事件通过长连接 推 给监听者

5. 监听者收到事件,做自己的业务逻辑
   (调度、重建Pod、运行容器...)

apiservice 内部监听etcd 变化

etcd 设计的时候就自带watch 而apiservice有etcd的客户端,所以apiservice能够监听etcd的变化。

这个etcd和apiservice的watch 与 apiservice 提供给其他组件的watch 不一样哈

思考

那k8s 就只能用etcd了吗? 不是 ,还有以下选择

etcd(官方默认)

TiKV(分布式 KV,支持 Watch)

ZooKeeper(支持 Watch)

Consul(支持 Watch)

相关推荐
heimeiyingwang27 分钟前
【架构实战】移动端网络优化:弱网加速方案
架构
Eric.Lee202132 分钟前
docker 启动停止命令
运维·docker·容器
数字孪生进化论41 分钟前
数字孪生渲染架构深度对比:端渲染 vs 流渲染 vs 双模融合
架构
万岳科技系统开发1 小时前
商城系统搭建自建平台与入驻第三方平台对比分析
数据库·小程序·架构
2501_933329552 小时前
技术深度拆解:Infoseek舆情处置系统的全链路架构与核心实现
开发语言·人工智能·自然语言处理·架构
2601_949925182 小时前
基于 OpenClaw 打造货代行业 AI 智能体架构实战
大数据·人工智能·架构·ai智能体
无心水3 小时前
OpenClaw技术文档/代码评审/测试用例生成深度实战
网络·后端·架构·测试用例·openclaw·养龙虾
数智顾问3 小时前
(107页PPT)数字化转型企业架构设计业务架构应用架构数据架构技术架构(附下载方式)
架构
Ai173163915793 小时前
GB200 NVL72超节点深度解析:架构、生态与产业格局
大数据·服务器·人工智能·神经网络·机器学习·计算机视觉·架构
一个有温度的技术博主4 小时前
微服务4:Spring Cloud 微服务实战:如何实现跨服务数据组装?
spring cloud·微服务·架构