k8s的两种网络转发规则及原理

一、核心定位

iptables内核Netfilter包过滤、NAT转发,k8s默认早起Service代理

IPVS:内核四层负载均衡,专门做流量调度

二、核心区别

1.调度能力

iptables:无调度算法,纯规则匹配转发

IPVS: 支持轮询、加权轮询、最小连接等多种调度算法

2.性能规模

iptables:规则海量时卡顿、延迟飙升,千级服务吃力

IPVS:哈希表调度,万级服务依旧稳定,高并发更强

3.连接模型

iptables:DNAT/SNAT逐条规则跳转

IPVS:四层负载转发,链路更简洁

4.会话保持

iptables:仅简单源IP绑定

IPVS:NAT/DR/TUN全支持,k8s常用NAT

三、两者联系

1.同属Linux内核网络模块,都处理四层流量

2.K8s Service二选一作为流量代理

3.IPVS底层仍依赖部分iptables规则做潜质过滤、端口拦截

4.都实现Service:ClusterIP->后端Pod转发

四、最简选型

小集群、业务少:iptables够用简单

大集群、高并发、多服务:IPVS性能更稳

五、K8s切换命令

#查看当前代理模式

kubectl get configmap kube-proxy -n kube-system -o yaml

#修改mode:ipvs即可切换

六、iptables原理

1.给予linux内核Netfilter钩子链,生成海量DNAT、SNAT、过滤规则存入内核

2.流量入栈,逐条对比规则,匹配成功就改写IP端口,转发至后段pod

3.无调度算法,仅按规则定向转发;服务增多,规则线性暴涨,匹配耗时变长

七、内核专属四层负载均衡模式,哈希表查表调度

1.kube-proxy维护虚拟服务、后端真实pod节点映射

2.流量抵达后,直接哈希检索映射,安轮询、加权轮询等算法挑选后端

3.完成IP/端口改写转发,表查询效率极高,海量服务下性能衰减极小

八、关联原理

1.共用内核网络协议栈,均实现ClusterIP到Pod的流量转发

2.IPVS运行时,会借用少量iptables规则做流量准入、边界拦截

3.都依靠内核NAT机制完成地址转换,仅调度检索方式不同

九、核心原理差异

iptables:链表遍历匹配,规则越多越慢

IPVS:哈希索引查询,算法调度,高并发稳定

相关推荐
专业机床数据采集21 分钟前
基于 Wireshark 抓包逆向设备通信协议,并用 C# UDP协议跨平台 实现宝元数控程序列表读取、上传、下载和删除
网络·测试工具·wireshark·程序传输·宝元数控·dnc·数控程序传输
信也科技布道师38 分钟前
从Istio 503 NC 错误深入理解 Mesh 路由全链路原理
java·服务器·网络
码云骑士1 小时前
28-Docker部署Django(下)-docker-compose编排与静态文件处理
docker·容器·django
A.零点2 小时前
【2个月 C 语言从入门到精通:零基础系统教程】第十二讲:深入了解指针(五)
c语言·开发语言·网络·笔记·visual studio
木雷坞2 小时前
Firecrawl Docker Compose 自托管排查:镜像、Redis、队列和 Playwright
redis·docker·容器·firecrawl
志栋智能2 小时前
从固定周期到动态触发:超自动化巡检的智能调度
运维·网络·自动化
whyfail3 小时前
Colima:把 Docker Desktop 从 Mac 上“瘦身”的那把刀
macos·docker·容器
小陈phd3 小时前
LCEL(LangChain Expression Language)语法全解
服务器·网络·langchain
DreamLife☼3 小时前
OpenBCI-可穿戴脑电设备设计与优化
网络·开源硬件·脑机接口·cca·ssvep·openbci·视觉刺激