Linux内核深度解析:IPv4策略路由的核心实现与fib_rules.c源码剖析
深入探索Linux网络栈的规则引擎,揭秘策略路由如何通过多级路由表实现复杂流量控制
在Linux网络栈中,路由决策远不止简单的目的地址匹配。策略路由(Policy Routing)允许根据源地址、TOS值、端口等复杂条件选择不同的路由路径。本文将深入剖析实现这一功能的核心源码——net/ipv4/fib_rules.c
,揭示策略路由的运作机制。
一、策略路由基础概念
策略路由打破了传统路由基于单一目的地址的限制,支持:
-
多路由表并行存在(最多255张)
-
基于源/目的地址、TOS、端口等条件的路由选择
-
灵活的路由优先级控制
-
流量分类(tclassid)支持
通过ip rule
命令可查看当前规则:
$ ip rule list 0: from all lookup local 32766: from all lookup main 32767: from all lookup default
二、核心数据结构剖析
1. fib4_rule:IPv4路由规则实体
struct fib4_rule {