首页 > 其他分享 >K8S组件详解

K8S组件详解

时间:2024-10-23 08:49:48浏览次数:6  
标签:容器 Controller 详解 组件 Pod K8S 节点


K8S的控制平面、和工作节点是集群正常运行的核心,通过这两部分的协同工作,K8S才能够实现高效的容器编排、管理、和自动化运维。

K8S

Kubernetes(简称K8s),是一个开源的容器编排平台,用于自动化部署、扩展和管理容器化应用程序。

K8S诞生于Google,基于其多年在生产环境中运行容器的经验,现已成为现代微服务架构、和云原生应用的核心技术。

图片图片

K8S通过管理容器的生命周期,确保系统在大规模的生产环境中,可以高效稳定地运行。

K8S组件

k8s采用主从架构,其中集群中的所有节点都由控制平面管理、和调度。

如下图所示:

图片图片

K8S组件,主要会包含两大最核心的组件:控制平面(Control Plane)、工作节点(Worker Nodes)。

控制平面(Control Plane):负责管理整个集群的状态,调度任务,监控集群正常运行;

工作节点(Worker Nodes):运行实际的应用容器,负责:容器的运行、和管理。

如果你想掌握好K8s,最核心的就是掌握好:控制平面(Control Plane)和工作节点(Worker Nodes)。

下面,我就分别详解:控制平面(Control Plane)和工作节点(Worker Nodes)@mikechen

控制平面组件

控制平面:负责管理 Kubernetes 集群中的所有节点、和 Pod。

它由以下组件组成,重点关注下图的“黄色框”:

图片图片

“黄色框”会涉及到如下组件:API Server、Scheduler、Controller...等核心组件。

API Server

API Server:它是集群的入口,类似微服务网关这样,所有操作必须通过 API Server。

负责接收来自用户、和其他组件的请求,并通过 REST API 提供集群管理功能。

Controller Manager

Controller Manager :是集群管理中的重要组件,它负责确保集群的实际状态与期望状态的一致性。

Controller Manager,是由多个控制器组成,每个控制器负责处理集群中的一种或、多种资源对象的状态管理。

如下图所示:

图片图片

每个控制器负责:特定类型的资源、或功能。

常见的控制器包括:

  • Deployment Controller:管理无状态应用的部署,包括“处理副本的创建、更新和滚动升级;
  • StatefulSet Controller:管理有状态应用的部署,适合需要持久化存储、和有序部署的应用(如:数据库);
  • ReplicaSet Controller:确保指定数量的 Pod 副本始终运行,用于确保 Pod 副本数目符合期望;
  • Job Controller:Job 可以创建多个 Pod,并在成功完成任务后终止 Pod;
  • CronJob Controller:类似于 Linux 的 Cron 任务,它会在指定的时间间隔内创建 Job 实例;
  • DaemonSet Controller:确保每个节点上都有一个 Pod 实例,适合需要在每个节点上运行的服务,如:日志收集器、监控代理...等;
  • Namespace Controller:管理命名空间的生命周期,包括:创建/和删除命名空间,以及相关资源的清理。

总之,控制器的设计使得 K8S,能够在大规模环境中自动化管理容器、和服务。

Scheduler

负责根据调度策略(如:资源使用率、亲和性...等),将新创建的 Pod 分配到合适的节点上。

比如:通过 CPU、内存、GPU ...等资源的要求,Scheduler 确保节点有足够的可用资源来满足 Pod 的需求。

并且,通过调度策略,比如:公平调度、优先级...等,确保资源的合理分配和高效利用。

etcd

分布式键值存储系统,用于保存集群的所有配置信息、和状态数据。

etcd,重点保证数据的一致性、和持久性。

以及,提供集群状态的快速读取、和修改能力。

工作节点的组件

工作节点组件:运行实际的应用容器,负责:容器的执行、和管理。

每个工作节点,包含以下“绿色框”所示组件:

图片图片

工作节点是运行实际应用程序的地方,它接收 API Server 的调度指令并运行 Pod。

工作节点上的核心组件包括:

Kubelet

每个节点上的代理,负责确保 Pod 正常运行。

Pod是 K8S中最小的可部署单元,通常由一个、或多个紧密耦合的容器组成。

如下图所示:

图片图片

Pod 是 Kubernetes 中的基本构建块,提供了容器的封装、和管理功能。

它们可以包含一个、或多个容器,这些容器共享:网络、存储资源,并在同一个环境中运行。

当创建一个 Pod 时,K8S调度器,会将 Pod 调度到合适的工作节点上。

调度器根据资源需求、节点的负载、和调度策略来选择节点。

一旦 Pod 被调度到节点上,kubelet 在节点上启动并运行 Pod 中的容器。

Kube-proxy

网络代理,管理网络规则,确保容器、和服务之间的网络通信。

比如:使用 iptables 、或 ipvs 维护网络规则,将流量转发到相应的 Pods。

容器运行时

负责运行容器,如:Docker、containerd 等。

主要复制:拉取容器镜像,创建、和运行容器。

以及,提供容器的生命周期管理,如:启动、停止和监控容器...等等。

总之,K8S的控制平面、和工作节点是集群正常运行的核心,通过这两部分的协同工作,K8S才能够实现高效的容器编排、管理、和自动化运维。

标签:容器,Controller,详解,组件,Pod,K8S,节点
From: https://www.cnblogs.com/lcword/p/18494338

相关文章

  • USB协议详解第19讲(USB包-包的组成及分类)
    1.包的组成下面这张图为包的组成结构,由SOP、SYNC、PacketContent、EOP四部分组成,其中PacketContent最为核心,PacketContent由PID、地址、帧号、数据、CRC组成。1.SOP域(StartOfPacket)通过将D+和D-线从空闲状态驱动到相反的逻辑电平(K状态),由始发端口发信号通知分组的开始(SOP......
  • UML之用例图详解
    ~犬......
  • Java调用第三方接口、http请求详解,一文学会
    系列文章目录提示:这里可以添加系列文章的所有文章的目录,目录需要自己手动添加例如:第一章Python机器学习入门之pandas的使用提示:写完文章后,目录可以自动生成,如何生成可参考右边的帮助文档文章目录系列文章目录前言一、pandas是什么?二、使用步骤1.引入库2.读入数据......
  • FreeRTOS学习——临界段代码保护及调度器挂起与恢复及其API函数内部实现详解
    FreeRTOS临界段代码保护及调度器挂起与恢复FreeRTOS临界段代码保护及调度器挂起与恢复临界保护区任务调度器挂起与恢复使用格式特点函数内部实现**vTaskSuspendAll();****==总结==**:xTaskResumeAll();FreeRTOS临界段代码保护及调度器挂起与恢复临界保护区什么......
  • 深度了解flink rpc机制(三)-组件以及交互
    FlinkRPC整体架构Flink集群间组件的通信底层是使用的actorsystem通信模型和动态代理来实现的,先简单看下FlinkRPC相关的类UML图通信组件RpcGatewayFlinkRPC远程调用网关,是FlinkRPC定义远程调用的接口协议,对外提供可调用的接口,所有实现RPC的组件,都要实现这个接口......
  • Dockerfile指令详解
    Dockerfile是一个用来构建镜像的文本文件,文本内容包含了一条条构建镜像所需的指令和说明。首先通过一张图来了解Docker镜像、容器和Dockerfile三者之间的关系。通过上图可以看出使用Dockerfile定义镜像,运行镜像启动容器。一、Dockerfile概念Docker镜像是一个特殊的文......
  • ArkUI-Image详解
    ArkUI-Image详解本地资源创建文件夹,将本地图片放入ets文件夹下的任意位置。Image组件引入本地图片路径,即可显示图片(根目录为ets文件夹)。Image('images/pic1.webp').width(100).height(100)Resource资源使用资源格式可以跨包/跨模块引入图片,resources文件......
  • Jetpack架构组件_LiveData组件
    1.LiveData初识LiveData:ViewModel管理要展示的数据(VM层类似于原MVP中的P层),处理业务逻辑,比如调用服务器的登陆接口业务。通过LiveData观察者模式,只要数据的值发生了改变,就会自动通知VIEW层,View层会设置观察者来监听数据的改变。MVP:P调用M层去获取数据,P回调View层实现的接口,......
  • Nacos K8s
    Nacos是DynamicNamingandConfigurationService的首字母简称,一个更易于构建云原生应用的动态服务发现、配置管理和服务管理平台。Nacos是构建以服务为中心的现代应用架构(例如微服务范式、云原生范式)的服务基础设施。更多的功能特性介绍请查看 Nacos概览。在本......
  • vue3 使用swiper轮播组件
    1.本地环境信息参考node版本:nodejs:v18.20.4npm:10.7.0vue版本"dependencies":{"vue":"^3.2.13",...}2.安装swiper依赖执行命令:npmiswiper安装后,查看工程中的package.json文件,新增了swiper依赖(默认最新版):"dependencies":{......