Kubernetes 架构

Kubernetes

  • Kubernetes 是 Google 开发的容器管理编排工具,用于跨不同集群管理自己的微服务。
  • Kubernetes,也称为 K8s,基本上是自 1980 年代以来使用的 Numeronym 标准。例如,在 K8s 中,K 和 S 之间有 8 个单词。
  • 谷歌开发了一个名为 Borg 的内部系统,后来命名为 Omega,他们用它来编排数据中心。
  • 2014 年,谷歌将 Kubernetes 作为开源引入,它是用 Golang 语言编写的。后来,捐赠给 CNCF。
  • Kubernetes 是一种自动化容器部署、负载平衡和自动扩展的工具。它将管理在不同环境中运行的所有容器。

Kubernetes 的特点

  • 编排支持:  Kubernetes 提供了一个集群来管理在不同环境中运行的多个容器。
  • 自动缩放应用程序: 它将根据我们的要求和网络流量自动缩放应用程序。
  • 自动化部署: 使用 Kubernetes,我们使用不同的云提供商服务自动化我们的部署过程。
  • 容错: 它将管理与容器相关的所有事物;假设我们的容器在不同的节点和 Pod 下运行,并且 Kubernetes 找到了其中一个 Pod,并且容器停止工作,那么它将管理传入的网络流量。
  • 负载平衡: 它将使用处于运行模式的不同节点和 Pod 来平衡我们应用程序的负载。
  • 独立于平台: 它将管理在不同环境下运行的所有类型的应用程序,如虚拟机、云和物理机。
  • 健康监控: 它将管理在不同类型 pod 下运行的容器的健康状况。
  • 回滚: 我们还可以使用 Kubernetes 回滚应用程序版本。
  • 批量执行: 我们还能够同时并行执行一些功能。

Kubernetes 的架构

Kubernetes 架构_第1张图片

Kubernetes 在运行应用程序时使用了两个节点,它们将一一看到。

Kubernetes 主节点

  • Master 负责管理整个集群。
  • 它有四个组件:ETCD、API Server、调度器和控制器管理器。
  • 用户可以使用 CLI 和 API Server 访问 Master。
  • Master 持续监视集群下的所有节点并采取行动。
  • 可以存在多个主节点以降低高可用性的容错。

以下是主节点的组件,

API 服务器

  • Master 可以通过 API Server 与所有集群通信。它是控制平面的主要接入点。
  • API Server 直接与用户交互。前用户能够将 YML 或 JSON 文件直接应用到 API 服务器。
  • API Server 能够根据负载自动扩展。
  • API Server 是控制平面的前端。

ETCD

  • ETCD 用于将数据存储为键值对,Kubernetes 使用这些键值对来管理集群。
  • 它还存储集群的元数据和状态。
  • ETCD 是一致且高可用性的数据存储。
  • 它还负责维护锁机制以减少Master之间的冲突。
  • 当我们有多个 Master 和 Nodes 时,ETCD 以分布式方式存储所有数据。

ETCD 具有以下特点:

  • 完全复制: 数据的整个状态在集群中存在的每个节点上都可用。
  • 安全: 它还实现了自动客户端 TLS 证书认证。
  • 快速:  ETCD 也非常快速,可以在几秒钟内轻松执行多项操作。

调度器

  • 调度器负责将工作分布在多个不同的可用节点上。
  • 它总是查看新创建的容器并分配节点。
  • 处理 Pod 的创建和管理。
  • 当用户提出创建和管理 Pod 的请求时,调度程序将顺利地针对该请求采取行动。

控制器管理器

  • 控制器是编排背后的主要内容。
  • 控制器不断查看和观察节点的健康状况,无论它是否响应,并根据它采取行动。
  • 它还管理与部署、副本和集群中运行的节点数相关的控制器状态。

它有以下两种选择:

  1. 如果 Kubernetes 在云上,那么它将是云控制器管理器。
  2. 如果 Kubernetes 不在云上,它将是 Kube-controller 管理器。

此外,主服务器中还存在以下不同的组件:

  • Route Controller:负责管理网络。
  • 节点控制器:如果没有响应,负责检测节点。
  • 服务控制器:负责负载均衡来管理负载。
  • Volume Controller:负责挂载和创建卷存储。

你可能感兴趣的:(kubernetes,架构,java)