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服务器,对于基础资源消耗较多。

相关推荐
没有bug.的程序员20 分钟前
微服务网关:从“必选项”到“思考题”的深度剖析
java·开发语言·网络·jvm·微服务·云原生·架构
没有bug.的程序员29 分钟前
Sentinel 流控原理深度解析:构建高可用微服务的底层架构
java·算法·微服务·云原生·架构·sentinel·负载均衡
ydswin34 分钟前
Sidecar不就是在Pod里多跑一个容器吗!
linux·kubernetes
前端程序猿之路1 小时前
AI大模型应用开发之容器化部署
人工智能·python·语言模型·云原生·eureka·ai编程·改行学it
回忆是昨天里的海1 小时前
docker网络-自定义网络
运维·docker·容器
飞Link2 小时前
【开发工具】Docker常用操作
运维·docker·容器
运维行者_2 小时前
网络流量分析入门:从流量监控与 netflow 看懂核心作用
运维·开发语言·网络·云原生·容器·kubernetes·php
hanyi_qwe2 小时前
Docker 容器操作 【docker (二)】
docker·容器·eureka
小白电脑技术3 小时前
简单点!异地访问Docker的方式简单点!
docker·容器·电脑
Zhen (Evan) Wang3 小时前
Docker 完整安装 Redis
redis·docker·容器