ip rule 策略路由

作者:疯狂吧小飞牛日期:2025/10/20

原文地址:ip rule 策略路由

欢迎参观我的网站:无敌牛 – 技术/著作/典籍/分享等

ip rule 是 Linux 策略路由(Policy-based Routing, PBR) 的核心命令,用于控制内核在查找路由时使用哪张路由表

一、ip rule 基本语法

ip rule [list|add|del] [selectors] [action]

  • selectors:匹配条件(如源 IP、入接口等)
  • action:匹配后执行的动作(最常见的是 table N,即使用路由表 N)

二、ip rule add from <IP> table <N>

含义:

  • 匹配源 IP 地址<IP>出站流量(即本机主动发出的数据包)。
  • 当本机发送一个包,其源 IP 是 192.168.1.XX,则使用路由表 <N> 查找下一跳。

举例:

ip rule add from 192.168.1.XX table 100

  • 当你从本机执行 ping 8.8.8.8,且系统选择 192.168.1.XX 作为源 IP 时,
  • 内核会去查 路由表 100,而不是默认的 main 表。

注意:

  • from 只对本机发出的流量生效(OUTPUT 和转发流量中的源 IP 匹配)。
  • 进入本机的流量(如别人 ping 你)不生效

三、ip rule add iif <interface> table <N>

含义:

  • 匹配从指定接口进入(ingress interface)的流量。
  • 通常用于转发流量响应入站请求的回包路径控制

举例:

ip rule add iif eth1 table 200

  • 所有从 eth1 接口进来的包(比如别人访问你 eth1 上的 IP),
  • 在决定如何回包时,会使用路由表 200 来查找出口。

注意:

  • iif lo 是一个特例:本地进程通信(如 curl http://127.0.0.1)也会触发 iif lo 规则。
  • 对于本机主动发起的连接iif 通常是 lo,而不是物理网卡。

四、其他常用 ip rule 匹配条件(selectors)

除了 fromiif,还有以下常用选项:

选项说明示例
to <IP>匹配目的 IP(出站或转发)ip rule add to 10.0.0.5 table 10
oif <iface>匹配出站接口(较少用,因路由决定出口)ip rule add oif eth0 table 20
fwmark <mark>匹配由 iptables/netfilter 打的标记ip rule add fwmark 0x10 table 30
priority <N>设置规则优先级(数值越小越先匹配)ip rule add from 192.168.1.56 table 100 priority 1000
tos <TOS>匹配 IP 头中的 TOS 字段(已逐渐被 DSCP 取代)ip rule add tos 0x10 table 40
protocol <proto>匹配路由协议(如 kernel, boot, static)较少用于策略路由
suppress_prefixlength <len>隐藏小于某前缀长度的路由(高级用法)

最常用的是:fromtoiiffwmarkpriority


五、规则匹配顺序:priority(优先级)

  • 所有规则按 priority 从小到大匹配。
  • 默认规则(如 0: from all lookup local)优先级为 03276632767
  • 自定义规则默认优先级是 自动分配(通常从 32765 往下),但强烈建议显式指定

查看当前规则及优先级:

ip rule show

输出示例:

10:    from all lookup local
21000: from 192.168.1.XX lookup 100
32000: iif eth1 lookup 200
432766: from all lookup main
532767: from all lookup default

建议:自定义规则用 priority 1000~10000 之间,避免与系统规则冲突。


六、典型应用场景

场景 1:多出口(双 WAN)

1ip rule add from 192.168.1.XX table wan1
2ip rule add from 192.168.1.YY table wan2

→ 不同 IP 走不同运营商线路。

场景 2:对称路由

1ip rule add iif eth1 table 100   # 从 eth1 进来的,回包查表 100
2ip route add default via 192.168.1.1 dev eth1 table 100

→ 确保回包从原入口返回。

场景 3:基于应用标记路由(配合 iptables)

1iptables -t mangle -A OUTPUT -p tcp --dport 443 -j MARK --set-mark 1
2ip rule add fwmark 1 table https_route

→ 所有 HTTPS 流量走特定路由。


七、注意事项

  1. 路由表必须存在table N 中的 N 必须在 /etc/iproute2/rt_tables 中定义(或直接用数字)。
  2. 规则不等于路由ip rule 只决定“查哪张表”,表里必须有实际路由(ip route add ... table N)。
  3. 本地地址优先local 表(优先级 0)会优先处理本机 IP,所以 from 规则通常在 local 之后生效。
  4. 调试命令ip route get 8.8.8.8 from 192.168.1.56 # 查看实际使用哪张表 ip rule show ip route show table 100

总结

选项作用适用流量方向
from <IP>源 IP 选路由表本机发出(OUTPUT)
iif <iface>入接口 选路由表入站(INPUT/FORWARD)
to <IP>目的 IP 选路由表所有方向
fwmark按防火墙标记选表高级流量分类

ip rule 策略路由》 是转载文章,点击查看原文


相关推荐


【汽车篇】AI深度学习在汽车轮胎X-ray缺陷检测应用方案
Dongsheng_20192025/10/19

一、行业痛点 轮胎安全=生命安全 起鼓、胎侧凹陷、开裂、微孔、气泡等内部缺陷肉眼不可见,传统人工敲听+抽检: 漏检率 2%–5%,一旦流出即面临召回及高额索赔; 节拍慢,单胎平均 45 s,无法满足 70 JPH 下线节奏; 结果无数据留存,难以追溯工艺根因。 二、技术方案 东声智能“AI+X-ray”在线检测系统,将穿透成像与深度学习合二为一,为轮胎内部质量打造零缺陷防线。 1.缺陷定位算法: 3D 模块精准标定起鼓、凹陷、气泡等 12 类缺陷中心坐标。 2.双擎决策:传统算法分


苦练Python第67天:光速读取任意行,linecache模块解锁文件处理新姿势
倔强青铜三 VIP.1 初学乍练2025/10/17

前言 大家好,我是 倔强青铜三。欢迎关注我,微信公众号: 倔强青铜三。点赞、收藏、关注,一键三连! 今天咱们把 Python 自带的“光速行读取器”—— linecache 模块,从开箱到实战一次性讲透。 一、为什么需要 linecache? 秒级随意读任意行:再也不用 for i, line in enumerate(f) 数行号。 内存缓存机制:同一个文件多次读取,只加载一次。 源码级调试神器:traceback、pdb 都在用它。 零依赖:官方出品,随 Python 一起安装。 li


Redis(65)如何优化Redis的AOF持久化?
Victor3562025/10/16

优化 Redis 的 AOF(Append-Only File)持久化机制可以提高数据持久化的效率和性能,并且能够确保数据的安全性和一致性。以下是关于如何优化 Redis AOF 持久化的详细指南,包括操作配置、代码示例及具体步骤。 1. AOF 持久化配置 Redis 提供了多个配置参数来调整 AOF 的行为,主要包括: appendonly appendfsync auto-aof-rewrite-percentage auto-aof-rewrite-min-size aof-load-


C#/.NET/.NET Core技术前沿周刊 | 第 57 期(2025年10.1-10.12)
追逐时光者2025/10/14

前言 C#/.NET/.NET Core技术前沿周刊,你的每周技术指南针!记录、追踪C#/.NET/.NET Core领域、生态的每周最新、最实用、最有价值的技术文章、社区动态、优质项目和学习资源等。让你时刻站在技术前沿,助力技术成长与视野拓宽。 欢迎投稿、推荐或自荐优质文章、项目、学习资源等。 🏆技术前沿周刊Gitee开源地址: gitee.com/ysgdaydayup… 📰技术前沿周刊GitHub开源地址: github.com/YSGStudyHar… 👪DotNetGuid


优选算法-二分:19.搜索插入位置
CoderYanger2025/10/13

题目链接:35.搜索插入位置(简单) 算法思路: 二分:二分查找该元素 没找到就返回最后一次查找的左边界下标(即为插入位置) Java代码: /** * Created with IntelliJ IDEA. * Description: * User: 王洋 * Date: 2025-08-28 * Time: 09:24 */ class Solution { //35. 搜索插入位置 /*给定一个排序数组和一个目标值,在数组中找到目标值,


RabbitMQ核心机制
00后程序员张2025/10/11

MQ 概述 MQ,消息队列,一种在分布式系统中用于通信的关键组件 本质上是一个队列,遵循 FIFO(先入先出)原则,队列中存储的内容是消息(message) 消息可以非常简单,比如只包含文本字符串或 JSON 数据,也可以很复杂,如内嵌对象。MQ 主要用于分布式系统之间的通信,解决数据传递的效率和可靠性问题 1.2 系统间通信方式 在分布式系统中,系统之间的调用通常有两种方式: 1.同步通信: 直接调用对方的服务,数据从一端发出后立即到达另一端。这种方式响应快,但可能导致调用方阻塞,尤


还在纠结用v-if还是v-show?看完这篇彻底搞懂Vue渲染机制!
良山有风来2025/10/10

你是不是也曾经在写Vue时纠结过:这里到底该用v-if还是v-show? 或者更惨的是,明明代码逻辑没问题,列表渲染却总是出现各种诡异bug:删除一个项,结果删错了;切换数据,页面状态全乱了... 别担心,今天我就来帮你彻底搞懂Vue的条件渲染和列表渲染,让你写出更优雅、更高效的代码! v-if和v-show:看似相似,实则大不相同 先来看个最简单的例子: <!-- v-if 的用法 --> <div v-if="isVisible">我会在条件为真时渲染</div> <!-- v-show


JavaScript性能优化实战:从指标到落地的全链路方案
weixin_439647792025/10/8

JavaScript性能优化实战:从指标到落地的全链路方案 实际项目中,性能优化往往不是单一手段的应用,而是“指标监测-瓶颈定位-方案实施-效果验证”的全链路过程。本文将结合电商、管理系统等真实场景,提供可落地的性能优化闭环方案。 一、性能指标体系:从“感觉卡顿”到“数据说话” 性能优化的第一步是建立可量化的指标体系,避免凭主观感受判断优化效果。前端核心性能指标可分为三类: 1. 加载性能指标 LCP(最大内容绘制):衡量首屏加载速度,目标值<2.5sTTI(交互时间):页面可完全交互


Flutter 开发:应用颜色使用 Class 还是 Enum?—— 你应该选择哪一个?
JarvanMo2025/10/7

在开始一个新的 Flutter 项目时,第一步就是定义你的颜色调色板(color palette) 。一个一致且可维护的颜色系统不仅能保持你的设计简洁,还能让你的应用扩展变得更加容易。 但这里有一个开发者经常面临的常见问题: 👉 在 Flutter 中,你是应该使用带有静态常量的 Class(类) ,还是使用 **Enum(枚举)**来管理颜色呢? 随着 Dart 2.17 中**增强型枚举(enhanced enums)**的到来,答案变得更有趣了。下面我们通过示例、优缺点来探讨这两种方法。


Qt Theme —— 纯 qss 的 Qt 主题
hubenchang05152025/10/5

#Qt Theme —— 纯 qss 的 Qt 主题 源码地址:https://github.com/hubenchang0515/QtTheme/ Qt Theme 是一个纯 qss 的 Qt 主题项目,能够极为简单对已有项目的风格进行改进。 支持 C++、PyQt5、PyQt6、PySide2、PySide6,并以 WebAssembly 的方式在 GitHub Pages 上发布。 #安装 这里演示一下在 Python 上的使用,首先进行安装: pip install QtTheme

首页编辑器站点地图

Copyright © 2025 聚合阅读

License: CC BY-SA 4.0