k8s的kube-prosy

kube-proxy 是 Kubernetes 节点上的网络组件,主要负责 Pod 网络和 Service 的流量转发

Service 本身只是 Kubernetes 的 API 对象,真正处理流量的是 各节点上的 kube-proxy

kube-proxy 职责流程

kube-proxy 是 Kubernetes 节点上的网络组件,负责 Service 流量转发和负载均衡。下面是其具体职责和流程。


1. 获取 Service 与 Pod 信息

  • 从 API Server 获取所有 Service 对象
  • 获取每个 Service 对应的后端 Pod(Endpoints)
  • 根据变化动态更新本地规则

2. 配置网络规则

  • 根据工作模式选择:
    • iptables:在 Node 内核配置规则,将 Service IP:Port 流量重定向到 Pod
    • IPVS:通过 IPVS 负载均衡将流量分发到后端 Pod
    • 用户态模式:kube-proxy 用户态进程转发流量
  • 保证流量能根据 Service → Pod 映射正确路由

3. 流量转发

  • 用户请求 Service ClusterIP / NodePort / LoadBalancer
  • 流量进入 请求所在 Node 的网络栈
  • kube-proxy 配置的规则触发,选择后端 Pod
  • 流量被转发到目标 Pod

4. 负载均衡

  • kube-proxy 根据算法(轮询、最少连接等)选择 Pod
  • 确保同一 Service 的请求均匀分布到多个 Pod

5. 动态更新与健康检查

  • 定期检查 Pod 状态
  • Pod 上线/下线时更新规则
  • 保证流量只转发到健康 Pod

总结

kube-proxy 通过维护 Service → Pod 映射规则,在节点上实现流量拦截、转发和负载均衡,确保访问 Service 的请求能够透明到达后端 Pod。

相关推荐
小敬爱吃饭17 小时前
Ragflow Docker部署及问题解决方案(界面为Welcome to nginx,ragflow上传文件失败,Docker中的ragflow-cpu-1一直重启)
人工智能·python·nginx·docker·语言模型·容器·数据挖掘
木子欢儿18 小时前
Docker Hub 镜像发布指南
java·spring cloud·docker·容器·eureka
H_老邪19 小时前
什么是云原生?
云原生
虚伪的空想家21 小时前
k8s集群configmap和secrets备份脚本
linux·容器·kubernetes
SXJR21 小时前
k8s中的Pod
云原生·容器·kubernetes
文静小土豆21 小时前
K8s 滚动更新在 Java 应用中的实践与优化
java·容器·kubernetes
w61001046621 小时前
CKA-2026-Ingress
云原生·容器·kubernetes·cka
bloglin999991 天前
docker logs 如何一直监听日志输出
运维·docker·容器
AI攻城狮1 天前
Anthropic 开源了 Claude 的 Agent Skills 仓库:文档技能的底层实现全公开了
人工智能·云原生·aigc
❀͜͡傀儡师1 天前
使用 Docker 部署 Neko 自托管虚拟浏览器(Firefox)
docker·容器·firefox