软件数据中心负载均衡方案(Alpha)
通过创建一个高度可用的负载均衡器在集群外部部署纯软件数据中心负载均衡器(LB),为多个 ALB 提供负载均衡能力,以确保业务操作的稳定。它支持仅 IPv4、仅 IPv6 或 IPv4 和 IPv6 双栈的配置。
目录
先决条件
-
准备两个或更多主机节点作为 LB。建议在 LB 节点上安装 Ubuntu 22.04 操作系统,以减少 LB 将流量转发到异常后端节点的时间。
-
在所有外部 LB 主机节点上预安装以下软件(本章以两个外部 LB 主机节点为例):
-
ipvsadm -
Docker (20.10.7)
-
-
确保每个主机的 Docker 服务在启动时启用,可以使用以下命令:
sudo systemctl enable docker.service。 -
确保每个主机节点的时钟已同步。
-
准备 Keepalived 的镜像,用于启动外部 LB 服务;该平台已经包含此镜像。镜像地址格式为:
<image repository address>/tkestack/keepalived:<version suffix>。版本后缀可能在不同版本间略有不同。您可以通过以下方式获取镜像仓库地址和版本后缀。本文档以build-harbor.alauda.cn/tkestack/keepalived:v3.16.0-beta.3.g598ce923为例。-
在 global 集群中执行
kubectl get prdb base -o json | jq .spec.registry.address获取 镜像仓库地址 参数。 -
在安装包解压目录中执行
cat ./installer/res/artifacts.json |grep keepalived -C 2|grep tag|awk '{print $2}'|awk -F '"' '{print $2}'获取 版本后缀。
-
操作步骤
注意:以下操作必须在每个外部 LB 主机节点上执行一次,并且主机节点的 hostname 不能重复。
-
将以下配置信息添加到文件
/etc/modules-load.d/alive.kmod.conf。 -
将以下配置信息添加到文件
/etc/sysctl.d/alive.sysctl.conf。 -
使用
reboot命令重启。 -
创建 Keepalived 配置文件的文件夹。
-
根据以下文件中的注释修改配置项,并将其保存在
/etc/keepalived/文件夹中,文件命名为alive.yaml。 -
在业务集群中执行以下命令检查配置文件中的证书到期日期,确保证书仍然有效。证书过期后,LB 功能将变得不可用,需联系平台管理员进行证书更新。
-
从 Kubernetes 集群中的三个主节点复制
/etc/kubernetes/admin.conf文件到外部 LB 节点的/etc/keepalived/kubecfg文件夹中,以索引命名,例如kubecfg01.conf,并在这三个文件中将apiserver节点地址修改为 Kubernetes 集群的实际节点地址。注意:平台证书更新后,此步骤需重新执行,覆盖原始文件。
-
检查证书的有效性。
-
从业务集群的主节点复制
/usr/bin/kubectl到 LB 节点。 -
执行
chmod +x /usr/bin/kubectl授予执行权限。 -
执行以下命令确认证书的有效性。
如果返回以下结果,则证书有效。
-
-
将 Keepalived 镜像上传到外部 LB 节点,并使用 Docker 运行 Keepalived。
-
在访问
keepalived的节点上运行以下命令:sysctl -w net.ipv4.conf.all.arp_accept=1。
验证
-
运行命令
ipvsadm -ln查看 IPVS 规则,您将会看到适用于业务集群 ALB 的 IPv4 和 IPv6 规则。 -
关闭 VIP 所在的 LB 节点,测试 IPv4 和 IPv6 的 VIP 能否成功迁移到另一个节点,通常在 20 秒内。
-
在非 LB 节点上使用
curl命令测试与 VIP 的通信是否正常。