不在 LAN 上的默认路由

Jar*_*und 2 networking linux static-routes routing gateway

我有一个原则上看起来像这样的网络:

H1---\           /----Inet1
H2---->---GW1---<
H3---/           \----GW2-----Inet2
Run Code Online (Sandbox Code Playgroud)
  • H1 和 H2 = 需要使用 GW1 访问互联网的主机
  • Inet1 = 通过 3G 连接的 Internet 链接
  • Inet2 = 5GHz 互联网链接(不总是打开)
  • GW1 = 用作路由器,自动选择 Inet1 和 Inet2(后者通过 GW2)之间的“最佳”连接。
  • GW2 = 5GHz wifi 路由器

这就是问题所在: H3 仅在 Inet2 启动时才需要访问互联网。我想做的是一个看起来像这样的路由表:

  • 通过 GW1 路由到 GW2
  • 默认路由是通过 GW2

我首先通过 GW1 设置到 GW2 的路由没有问题。但是当我尝试

路由添加默认 gw 1​​.2.3.4

(1.2.3.4 是 GW2 的 IP),它抱怨“SIOCADDRT:没有这样的设备”是我尝试设置的默认网关无法直接访问的问题吗?是否有不同的方法可以让我实现这一目标?

另一种(和假设的)方法:由于 H3 将使用静态 IP,是否有可能对 GW1 上的 iptables 做一些魔术来将任何数据包从 H3 转发到 GW3,从而“欺骗”H3 使用 GW2 作为其默认路由器?

PS:这个问题这个问题的后续问题。

小智 5

您的替代方法可以通过使用基于策略的路由来实现。类似于(命令应该在 GW1 上执行):

# Create rule for matching the source address in route table 999
ip rule add from 1.2.3.4/32 table 999
# Add default router to the table
ip route add default via <GW2> table 999
Run Code Online (Sandbox Code Playgroud)

我无法测试这些命令,但它们应该是正确的。表 999 中的路由规则在正常情况下不可见$ ip route show- 您需要附加表 id: $ ip route show table 999