多网卡如何区分路由,使用宽松模式测试网络

一、什么是 Linux 的"非对称路由"

1️⃣ 定义(先给结论)

非对称路由指的是:

数据包从 A 网卡进来,但回包却从 B 网卡出去

在多网卡、多出口服务器上非常常见,比如:

  • 双网卡

  • 多默认网关

  • 同一台服务器连多个网络

你之前的情况就是典型的非对称路由。


2️⃣ Linux 默认为什么不喜欢非对称路由?

因为它可能意味着:

  • IP 欺骗(spoofing)

  • 流量劫持

  • 路由异常

所以 Linux 默认启用了一个安全机制:

👉 反向路径过滤(Reverse Path Filtering,rp_filter)


二、rp_filter 的三种模式(重点)

rp_filter 就是你问的关键。

查看当前模式

sysctl net.ipv4.conf.all.rp_filter


1️⃣ strict 模式(严格模式)------默认

net.ipv4.conf.all.rp_filter = 1

行为:

如果一个包从网卡 X 进来

但根据路由表,回这个源地址不该走 X

直接丢包

📌 特点:

  • 安全

  • 不允许非对称路由

  • 多出口服务器必踩坑


2️⃣ loose 模式(宽松模式)⭐

net.ipv4.conf.all.rp_filter = 2

行为(你重点要记这个):

只要系统中存在一条到源 IP 的路由

不管从哪个网卡进

都放行

📌 关键差异:

模式 要求
strict (1) 回包接口必须一致
loose (2) 只要能路由到就行

👉 允许非对称路由


3️⃣ off(完全关闭)

net.ipv4.conf.all.rp_filter = 0

行为:

  • 不做任何检查

  • 安全性最低

  • 极少推荐


三、宽松模式(loose mode)怎么配置?

1️⃣ 临时生效(立刻测试)

sysctl -w net.ipv4.conf.all.rp_filter=2 sysctl -w net.ipv4.conf.default.rp_filter=2 # 单独网卡(可选) sysctl -w net.ipv4.conf.enp132s0f0.rp_filter=2 sysctl -w net.ipv4.conf.enp132s0f1.rp_filter=2


2️⃣ 永久生效(重启不丢)

编辑:

vi /etc/sysctl.conf

加入:

net.ipv4.conf.all.rp_filter = 2 net.ipv4.conf.default.rp_filter = 2

应用:

sysctl -p

四、宽松模式能解决你之前的问题吗?

👉

你的场景:

  • 外部 ping 10.xx.247.2

  • 请求进 enp132s0f1

  • 回包走 enp132s0f0

  • strict 模式 → ❌ 丢包

  • loose 模式 → ✅ 放行

所以你会看到:

不开策略路由,只改 rp_filter=2,也能 ping 通


五、那为什么我还是强烈推荐"策略路由"?(说人话)

宽松模式 = 放行

策略路由 = 控制

方案 能否解决 安全性 可控性
rp_filter=2
策略路由
rp_filter=0

生产环境建议:

  • 策略路由 + strict

  • ✔ 或 策略路由 + loose

  • ❌ 不建议:只靠 loose


六、什么时候"宽松模式"是合理选择?

✅ 适合场景

  • 负载均衡器后端

  • 非对称设计是刻意的

  • 网络结构你完全可控

  • 临时排障、验证

❌ 不适合场景

  • 公网服务器

  • 防火墙、边界设备

  • 不清楚流量路径的环境

相关推荐
艾莉丝努力练剑2 小时前
【Linux网络】Linux 网络编程:HTTP(三)HTTP 协议原理
linux·运维·服务器·网络·c++·http
Gauss松鼠会2 小时前
GaussDB(DWS) 资源监控Topsql
java·网络·数据库·算法·oracle·性能优化·gaussdb
minji...2 小时前
Linux 网络基础之网络IP层(十一)私有IP地址和公网IP地址,运营商和全球网络,理解公网
linux·服务器·网络·nat·内网·公网·运营商
薇茗2 小时前
【初阶数据结构】 升沉有序的平仄 排序 3
c语言·开发语言·数据结构·算法·排序算法·文件归并排序
字节高级特工2 小时前
C++11(一) 革新:右值引用与移动语义
java·开发语言·c++·人工智能·后端
郝学胜-神的一滴2 小时前
系统设计 012:从用户系统出发,吃透缓存、数据库与高并发设计
java·数据库·python·缓存·php·软件构建
米高梅狮子2 小时前
01.ELK企业日志分析系统
运维·服务器·网络·数据库·elk·oracle
AI科技星2 小时前
强哥德巴赫猜想(1+1)终极证明(2026 年5月 21 日)
开发语言·人工智能·算法·计算机视觉·量子计算
故事和你912 小时前
洛谷-【图论2-4】连通性问题2
开发语言·数据结构·c++·算法·动态规划·图论
Brilliantwxx2 小时前
【C++】 二叉搜索树
开发语言·c++·算法