k8s高可用集群部署介绍 -- 理论

部署官网参考文档
负载均衡参考
官网两种部署模式拓扑图和介绍

介绍两种高可用模式

  1. 堆叠

    拓扑图如下(图片来自k8s官网):

    特点:将etcd数据库作为控制平台的一员,由于etcd的共识算法,所以集群最少为3个,kube-apiserver使用负载均衡器暴露给工作节点。

    优点 : 相比与外部etcd部署模式,比较节省基础设施资源,将控制平面和 etcd 成员耦合在同一节点上。相对使用外部 etcd 集群, 设置起来更简单,而且更易于副本管理。
    缺点: 堆叠集群存在耦合失败的风险,如果一个节点发生故障,则 etcd 成员和控制平面实例都将丢失, 并且冗余会受到影响。你可以通过添加更多控制平面节点来降低此风险。

    这里说的"冗余会受到影响",指的是etcd 集群的可允许失败的节点数为 n = n-1/2

    n代表节点,这就意味着,必须有3个etcd节点才能保证etcd高可用性。

2.外部etcd

拓扑图如下(图片来自k8s官网):

特点: 将etcd集群独立出去。每个etcd主机与每个控制平面节点的kube-apiserver通信,所有etcd数量等于k8s kube-apiserver服务器数量,kube-apiserver使用负载均衡器暴露给工作节点。

优点: 控制平面的宕机不会影响etcd集群,增加了etcd集群的HA,失去控制平面实例或者 etcd 成员的影响较小。

缺点: 由于每个etcd对应一个kube-apiserver,所以至少需要 3 台etcd主机和3台kube-apiserver服务器,对于基础资源消耗较多。

相关推荐
文静小土豆10 分钟前
在K8S集群中部署EFK日志收集
docker·容器·kubernetes
一个向上的运维者18 分钟前
k8s的flannel生产实战与常见问题排查
云原生·容器·kubernetes
不之道37 分钟前
通过 wsl 安装 docker
运维·docker·容器
ZHOU_WUYI1 小时前
Milvus Docker 部署教程
docker·容器·milvus
东方未明01082 小时前
docker(四)使用篇一:docker 镜像仓库
docker·容器·镜像仓库
Mr.小海3 小时前
k8s 1.10.26 一次containerd失败引发kubectl不可用问题
云原生·容器·kubernetes
ChironW4 小时前
Ubuntu 22.04.5 LTS上部署Docker及相关优化
ubuntu·docker·容器
why1514 小时前
微服务商城(1)开篇、服务划分
微服务·云原生·架构
sg_knight7 小时前
从单体架构到微服务:架构演进之路
java·spring boot·spring·spring cloud·微服务·云原生·架构
eternal__day7 小时前
Spring Cloud:构建云原生微服务架构的最佳工具和实践
java·spring cloud·微服务·云原生·架构