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 在运行应用程序时使用了两个节点,它们将一一看到。
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 的请求时,调度程序将顺利地针对该请求采取行动。
控制器管理器
- 控制器是编排背后的主要内容。
- 控制器不断查看和观察节点的健康状况,无论它是否响应,并根据它采取行动。
- 它还管理与部署、副本和集群中运行的节点数相关的控制器状态。
它有以下两种选择:
- 如果 Kubernetes 在云上,那么它将是云控制器管理器。
- 如果 Kubernetes 不在云上,它将是 Kube-controller 管理器。
此外,主服务器中还存在以下不同的组件:
- Route Controller:负责管理网络。
- 节点控制器:如果没有响应,负责检测节点。
- 服务控制器:负责负载均衡来管理负载。
- Volume Controller:负责挂载和创建卷存储。