Kubernetes组件

Kubernetes 组件

在这里插入图片描述

Kubernetes 集群核心组件由控制平台和一个或多个工作节点组成。

核心组件

  • 控制平台组件:管理集群的整体状态。

    • kube-apiserver:公开 Kubernetes HTTP API 的核心组件服务器。负责处理接受请求的工作。 API 服务器是 Kubernetes 控制平面的前端。Kubernetes API 服务器的主要实现是 kube-apiserver。 kube-apiserver 设计上考虑了水平扩缩,也就是说,它可通过部署多个实例来进行扩缩。 可以运行 kube-apiserver 的多个实例,并在这些实例之间平衡流量
    • etcd:具备一致性和高可用性的键值存储,用于所有 API 服务器的数据存储。
    • kube-scheduler:查找尚未绑定到节点的 Pod,并将每个 Pod 分配给合适的节点。调度决策考虑的因素包括单个 Pod 及 Pods 集合的资源需求、软硬件及策略约束、 亲和性及反亲和性规范、数据位置、工作负载间的干扰及最后时限。
    • kube-controller-manager:运行控制器1来实现 Kubernetes API 行为。从逻辑上讲, 每个控制器都是一个单独的进程, 但是为了降低复杂性,它们都被编译到同一个可执行文件,并在同一个进程中运行。
    • cloud-controller-manager (可选):与底层云驱动集成2。嵌入了特定于云平台的控制逻辑。 云控制器管理器(Cloud Controller Manager)允许将集群连接到云提供商的 API 之上, 并将与该云平台交互的组件同与集群交互的组件分离开来。cloud-controller-manager 仅运行特定于云平台的控制器。 与 kube-controller-manager 类似,cloud-controller-manager 将若干逻辑上独立的控制回路组合到同一个可执行文件中,以同一进程的方式运行。 可以对其执行水平扩容(运行不止一个副本)以提升性能或者增强容错能力。
  • 工作组件:在每个节点上运行,维护运行的Pod并提供 Kubernetes 运行时环境。

    • kubelet:确保 Pod 及其容器正常运行。kubelet 接收一组通过各类机制提供给它的 PodSpec,确保这些 PodSpec 中描述的容器处于运行状态且健康。 kubelet 不会管理不是由 Kubernetes 创建的容器。
    • kube-proxy(可选):维护节点上的网络规则以实现 Service 的功能。kube-proxy 维护节点上的一些网络规则, 这些网络规则会允许从集群内部或外部的网络会话与 Pod 进行网络通信。如果操作系统提供了可用的数据包过滤层,则 kube-proxy 会通过它来实现网络规则。 否则,kube-proxy 仅做流量转发。
    • 容器运行时(Container runtime):负责运行容器的软件。负责管理 Kubernetes 环境中容器的执行和生命周期。Kubernetes 支持许多容器运行环境,例如 containerd、 CRI-O 以及 Kubernetes CRI (容器运行环境接口) 的其他任何实现。

插件

Kubernetes 支持通过插件的方式对其进行功能扩展,典型的插件有:

  • DNS:集群范围内的 DNS 解析。是一个 DNS 服务器,和环境中的其他 DNS 服务器一起工作,它为 Kubernetes 服务提供 DNS 记录。Kubernetes 启动的容器自动将此 DNS 服务器包含在其 DNS 搜索列表中。
  • Web 界面(Dashboard):通过 Web 界面进行集群管理。Dashboard 是 Kubernetes 集群的通用的、基于 Web 的用户界面。 它使用户可以管理集群中运行的应用程序以及集群本身,并进行故障排除。
  • 容器资源监控:用于收集和存储容器指标。将关于容器的一些常见的时序度量值保存到一个集中的数据库中,并提供浏览这些数据的界面。
  • 集群层面日志:用于将容器日志保存到中央日志存储。负责将容器的日志数据保存到一个集中的日志存储中, 这种集中日志存储提供搜索和浏览接口。

链接


  1. 控制器有许多不同类型。以下是一些例子:

    • Node 控制器:负责在节点出现故障时进行通知和响应
    • Job 控制器:监测代表一次性任务的 Job 对象,然后创建 Pod 来运行这些任务直至完成
    • EndpointSlice 控制器:填充 EndpointSlice 对象(以提供 Service 和 Pod 之间的链接)。
    • ServiceAccount 控制器:为新的命名空间创建默认的 ServiceAccount。
    ↩︎
  2. 下面的控制器都包含对云平台驱动的依赖:

    • Node 控制器:用于在节点终止响应后检查云平台以确定节点是否已被删除
    • Route 控制器:用于在底层云基础架构中设置路由
    • Service 控制器:用于创建、更新和删除云平台上的负载均衡器
    ↩︎
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值