k8s-架构

一、Kubernetes是什么

编排和调度容器的软件,方便实现服务发现,伸缩自愈等功能。

二、Kubernetes集群架构

一文讲清K8S整体架构 - 知乎

2.1 Master节点(集群控制节点)

Master节点是集群的控制节点,由API Server、Manager Controller、ETCD、Scheduler四个组件构成。

API Server:唯一操作ETCD入口,提供REST API(包括数据授权,校验,集群状态变更)。模块交互中心,负责Master模块之前,Master与Worker模块之间交互。

Controller Manager:集群级功能,例如复制组件,跟踪Node节点,处理节点故障等等。

ETCD:集群、Pod 等持久话信息存储。

Scheduler:应用组件调度。

2.2 Node节点(容器运行节点)

Kubelet:kubelet主要负责同Container Runtime打交道,并与API Server交互,管理节点上的容器。(Master在Node上的代理,管理容器声明周期。每个节点上都运行一个 kubelet 服务进程,默认监听 10250 端口,接收并执行 master 发来的指令,管理 Pod 及 Pod 中的容器。每个 kubelet 进程会在 API Server 上注册节点自身信息,定期向 master 节点汇报节点的资源使用情况,并通过 cAdvisor 监控节点和容器的资源。)

Kube-Proxy:在Node上实现Pod的网络代理。解决节点上应用的访问问题。

Container Runtime: 运行容器。

三、Pod创建流程

1、用户通过kubectl发起Pod创建请求,API Server接收创建Pod请求,将yaml信息记录到ETCD上。

2、Scheduler通过API Server watch 接口,Scheduler寻找合适Node分配Pod资源,将Pod绑定信息,返回API Server并让其记录到ETCD。

3、API Server 发送Pod信息给kubelet,kubelet操作Container runtime完成Pod容器创建。并返回状态结果记录到ETCD。调用CNI接口给pod创建pod网络,调用CRI接口去启动容器,调用CSI进行存储卷的挂载(网络,容器,存储卷)。

详见如下流程图和时序图展示Pod创建流程

相关推荐
拾忆,想起24 分钟前
Dubbo服务超时与重试策略配置指南:构建 resilient 微服务架构
服务器·网络·微服务·云原生·架构·dubbo
杭州杭州杭州1 小时前
实验3 微服务介绍以及开发环境搭建
微服务·云原生·架构
芥子沫2 小时前
日记应用推荐-Docker安装DailyNotes应用
docker·容器·日记
p***c9496 小时前
后端在微服务中的服务网关
微服务·云原生·架构
2501_9418814010 小时前
Kubernetes 容器集群资源调度与弹性扩容高可用架构在互联网业务实战经验总结
云原生·容器·kubernetes
究極の法則に通じた野犬10 小时前
k8s设计理念-k8s中哪些服务要部署成StatefulSet哪些部署成Deployment
云原生·容器·kubernetes
wuxingge10 小时前
k8s集群误删node节点,怎么添加回去
云原生·容器·kubernetes
观测云13 小时前
Kubernetes CRD 方式配置容器日志采集最佳实践
容器·kubernetes·日志分析
运维-大白同学19 小时前
2025最全面开源devops运维平台功能介绍
linux·运维·kubernetes·开源·运维开发·devops
努力进修1 天前
跨设备文件共享零烦恼!PicoShare+cpolar让跨设备传输更简单
云原生·eureka·cpolar