0

0

Linux kind 的 multi-node 配置与 metallb 负载均衡集成

舞姬之光

舞姬之光

发布时间:2026-02-20 16:09:02

|

426人浏览过

|

来源于php中文网

原创

kind multi-node集群默认不支持loadbalancer因docker无真实云lb,k8s卡pending;需禁用kind内置lb(设disabledefaultcni: true)并配metallb layer 2模式,ip池须在kind子网内且speaker启用hostnetwork。

linux kind 的 multi-node 配置与 metallb 负载均衡集成

为什么 kind 的 multi-node 集群默认不支持 LoadBalancer 类型 Service

因为 kind 底层用的是 Docker 容器模拟节点,没有真实云厂商的负载均衡器,Kubernetes 会卡在 pending 状态,kubectl get svc 显示 EXTERNAL-IP <pending></pending>。这不是配置错了,是机制上缺一环——得自己补个 LoadBalancer 实现,metallb 就是干这个的。

metallb 前必须关掉 kind 的默认 LoadBalancer 模拟

kind v0.20+ 默认启用了实验性内置 LB(基于 docker network 和端口映射),它和 metallb 冲突:两个组件同时抢 LoadBalancer 类型 Service,会导致 IP 分配混乱、健康检查失败、甚至 metallbspeaker 不工作。

关闭方式很简单,在 kind 配置文件里显式禁用:

kind: Cluster
apiVersion: kind.x-k8s.io/v1alpha4
networking:
  disableDefaultCNI: true  # 必须设为 true
  # 不要写 loadBalancer: {} 或类似字段

常见错误:

  • 只删了 loadBalancer 字段但没设 disableDefaultCNI: true → 内置 LB 还在运行
  • kind create cluster --config=... 重装集群但忘了删旧集群 → 旧容器残留网络规则,新 metallb 无法绑定 IP
  • 没清理 docker network inspect kind 里的 com.docker.network.bridge.host_binding_ipv4 相关配置 → 导致 metallb 分配的 IP 被 Docker 拦截

metallb 的 Layer 2 模式怎么配才不丢包

multi-node kind 集群里,metallb 只能用 layer2 模式(不能用 bfdbgp,因为 Docker 网络不支持跨容器 BGP 会话)。但 Layer 2 有个硬伤:ARP 广播只在二层广播域有效,而 kind 多节点其实是多个容器连在同一个 Docker 网桥上——看似同网段,实则内核 ARP 表可能不更新,导致流量发到旧 MAC 地址上,连接超时。

阿里云AI平台
阿里云AI平台

阿里云AI平台

下载

关键修复点:

  • metallbConfigMap 指定一个**严格落在 kind 网络子网内**的 IP 池,比如 kind 默认网段是 172.18.0.0/16,那就配 172.18.255.200-172.18.255.250,别用 192.168.x.x 这种外部网段
  • 确保所有 kind 节点容器都运行在同一个自定义 Docker 网络(不是默认 bridge),并在 kind 配置中显式指定:
    networking:
      podSubnet: "172.18.0.0/16"
      serviceSubnet: "172.18.255.0/24"
  • metallbspeaker DaemonSet 必须加 hostNetwork: true,否则它收不到本机之外的 ARP 请求

kind multi-node + metallb 后,curl 访问 LoadBalancer IP 却超时

最常见原因是宿主机防火墙或 Docker 网络策略拦截了目标端口。metallb 分配的 IP 是虚拟的,靠 ARP 响应“冒充”成当前 leader 节点的 MAC 地址,但流量最终仍得进该节点的网络栈——而 kind 节点容器默认不暴露端口到宿主机,所以你在宿主机 curl 172.18.255.200:80 会失败。

解决路径只有两条:

  • 在宿主机上用 docker exec -it kind-worker curl http://172.18.255.200:80 测试(验证 metallb 内部通不通)
  • 真要从宿主机访问,得手动把 metallb IP 池里的某个 IP 绑定到宿主机网卡:
    sudo ip addr add 172.18.255.200/32 dev docker0
    ,并确保 docker0 网桥开启了 proxy_arp
    sudo sysctl -w net.ipv4.conf.docker0.proxy_arp=1
  • 别碰 iptables 规则:kind 自带 iptables 链(如 KIND-MASQ),手动加规则容易被覆盖或冲突

Layer 2 模式下没有“高可用切换”的实时感知,节点宕机后 ARP 缓存可能长达几十秒才失效,这期间请求会黑屏——这不是 bug,是协议限制,没法绕开。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
curl_exec
curl_exec

curl_exec函数是PHP cURL函数列表中的一种,它的功能是执行一个cURL会话。给大家总结了一下php curl_exec函数的一些用法实例,这个函数应该在初始化一个cURL会话并且全部的选项都被设置后被调用。他的返回值成功时返回TRUE, 或者在失败时返回FALSE。

452

2023.06.14

linux常见下载安装工具
linux常见下载安装工具

linux常见下载安装工具有APT、YUM、DNF、Snapcraft、Flatpak、AppImage、Wget、Curl等。想了解更多linux常见下载安装工具相关内容,可以阅读本专题下面的文章。

181

2023.10.30

堆和栈的区别
堆和栈的区别

堆和栈的区别:1、内存分配方式不同;2、大小不同;3、数据访问方式不同;4、数据的生命周期。本专题为大家提供堆和栈的区别的相关的文章、下载、课程内容,供大家免费下载体验。

420

2023.07.18

堆和栈区别
堆和栈区别

堆(Heap)和栈(Stack)是计算机中两种常见的内存分配机制。它们在内存管理的方式、分配方式以及使用场景上有很大的区别。本文将详细介绍堆和栈的特点、区别以及各自的使用场景。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

594

2023.08.10

k8s和docker区别
k8s和docker区别

k8s和docker区别有抽象层次不同、管理范围不同、功能不同、应用程序生命周期管理不同、缩放能力不同、高可用性等等区别。本专题为大家提供k8s和docker区别相关的各种文章、以及下载和课程。

265

2023.07.24

docker进入容器的方法有哪些
docker进入容器的方法有哪些

docker进入容器的方法:1. Docker exec;2. Docker attach;3. Docker run --interactive --tty;4. Docker ps -a;5. 使用 Docker Compose。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

512

2024.04.08

docker容器无法访问外部网络怎么办
docker容器无法访问外部网络怎么办

docker 容器无法访问外部网络的原因和解决方法:配置 nat 端口映射以将容器端口映射到主机端口。根据主机兼容性选择正确的网络驱动(如 host 或 overlay)。允许容器端口通过主机的防火墙。配置容器的正确 dns 服务器。选择正确的容器网络模式。排除主机网络问题,如防火墙或连接问题。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

411

2024.04.08

docker镜像有什么用
docker镜像有什么用

docker 镜像是预构建的软件组件,用途广泛,包括:应用程序部署:简化部署,提高移植性。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

447

2024.04.08

pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法
pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法

本专题系统整理pixiv网页版官网入口及登录访问方式,涵盖官网登录页面直达路径、在线阅读入口及快速进入方法说明,帮助用户高效找到pixiv官方网站,实现便捷、安全的网页端浏览与账号登录体验。

776

2026.02.13

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PostgreSQL 教程
PostgreSQL 教程

共48课时 | 9.4万人学习

Git 教程
Git 教程

共21课时 | 3.7万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号