Kubernetes 负载均衡现象解析:为何同一批次请求集中于单个 Pod

背景

在 Windows 上使用 Kind 创建本地 Kubernetes 集群并集成Traefik 进行负载均衡》在这篇文章中,通过这个命令验证负载均衡。

bash 复制代码
 1..10 | ForEach-Object {
   curl.exe http://hello.local
}

实际的情况是:

比如,我第一次执行这个命令,所有的请求全部打到pod1中,过一会再执行这个命令,所有的请求全部打到pod2中,再过一会儿执行这个命令,所有的请求全部打到pod3中。

和预期并不相符合:

为什么for循环中10次请求,没有分别打到不同的pod中呢? 这个traefik的负载均衡,是实现把流量转发到不同的pod中么?如果是转发到不同的pod中,是如何实现的呢?

同一批次请求集中到一个 Pod,间隔后切换的核心原因是 Kubernetes Service 的会话亲和性(Session Affinity)与连接复用 共同作用的结果。

当前负载均衡的实际链路

从配置来看,流量路径是:
客户端(curl)→ Traefik → Kubernetes Service(NodePort)→ Pod

其中,实际的 Pod 负载均衡是由 Kubernetes Service 完成的 ,而非 Traefik。因为你的 Traefik 配置中,hello-service只指向了一个后端(Kubernetes Service 的 NodePort:http://172.18.0.2:32599),Traefik 自身并没有感知到多个 Pod 的存在,只是单纯将所有请求转发给这个 NodePort。

为什么同一批次请求会集中到一个 Pod?

Kubernetes Service 默认的负载均衡策略是 轮询(Round Robin) ,但存在一个关键特性:对同一客户端连接的请求会 "粘住" 同一个 Pod(默认启用短时间的会话亲和性)。

具体来说:

  1. curl命令在默认情况下会启用 HTTP/1.1 的长连接(Keep-Alive),10 次循环请求会复用同一个 TCP 连接。
  2. Kubernetes Service 检测到这是同一个连接,会将该连接上的所有请求转发到同一个 Pod(这是为了避免分布式场景下的会话状态丢失,是默认优化)。
  3. 当连接断开(间隔一段时间后),新的连接会触发 Service 重新轮询到下一个 Pod,因此你会看到 "间隔后切换 Pod" 的现象。
相关推荐
炸炸鱼.8 小时前
Kubernetes高级调度02:Taint/Toleration、Cordon/Drain、亲和性与反亲和性完全指南
云原生·容器·kubernetes
wanhengidc8 小时前
服务器租用有何优点
运维·服务器·安全·web安全
ZGi.ai8 小时前
人工审查节点:让自动化工作流多一步人工把关
运维·人工智能·自动化·人机协同·智能体工作流·人工审查
艾莉丝努力练剑8 小时前
【Linux:文件】Ext系列文件系统进阶
linux·运维·服务器·c++·文件系统·文件io·ext
海市公约8 小时前
Linux核心基础命令与权限管理实战指南
linux·运维·服务器·vim·权限管理·系统监控·命令行
wkd_0079 小时前
Ubuntu 22.04 Samba 连接故障排查记:从“用户名或密码错误”到 NTLM 版本不兼容
linux·运维·ubuntu
企服AI产品测评局9 小时前
Agent适配信创环境实测:企业级自动化如何实现国产操作系统与数据库全兼容?
运维·数据库·人工智能·ai·chatgpt·自动化
mixboot10 小时前
Linux 进程工作目录查看利器:pwdx 命令详解
linux·运维·服务器
盖小雅10 小时前
自动化排班如何破解劳动法合规难题:从规则冲突到可追溯的排班表
大数据·运维·机器学习·自动化
NiceCloud喜云11 小时前
Claude Code Routines 实战:三种触发器跑通云端自动化编码
android·运维·数据库·人工智能·自动化·json·飞书