AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / server / 问题 / 1000461
Accepted
ForJ9
ForJ9
Asked: 2020-01-27 10:10:42 +0800 CST2020-01-27 10:10:42 +0800 CST 2020-01-27 10:10:42 +0800 CST

在单独的路由表中没有路由的情况下不同接口的可访问性

  • 772

我们目前正在尝试通过wireguard 隧道将来自guest vlan (eth1.251) 子网的所有数据包路由到互联网。为了实现这一点,我们使用基于策略的路由,并在流量来自我们的访客子网时使用路由表 10 的规则:

32765:  from 10.251.0.0/16 lookup 10

在路由表 10 中,我们创建了一条通向隧道接口的默认路由:

default dev wg1  scope link

我们访客网络中的所有客户端都能够通过预期的wireguard隧道访问互联网,但是客户端无法到达访客网络的网关(10.251.0.1)。TCPDump 显示 ICMP 回显回复通过wg1接口路由回我们的隧道端点,这显然不是故意的。一个快速的解决方案是将eth1.251访客 vlan 接口的范围链接路由添加到路由table 10:

default dev wg1  scope link 
10.251.0.0/16 dev eth1.251  proto kernel  scope link 

现在客户端可以访问路由器接口并为其服务。


在这个路由器上有另一个接口 eth1 与子网192.168.0.1/16。当我们现在删除新添加的10.251.0.0/16路由时,table 10我们无法再访问路由器接口10.251.0.1,但是我们仍然能够192.168.0.1从子网上的客户端访问接口10.251.0.0/16。192.168.0.2子网中路由器后面的客户端(例如)192.168.0.0/16无法从10.251.0.0/16.

主要问题:为什么我们可以在192.168.0.1没有显式路由表条目的情况下访问路由器上的接口 ip,但不能10.251.0.1访问来宾10.251.0.0/16子网中客户端的接口 ip?

这是网络结构的概述。我认为这有助于理解我们的设置。

路由器接口概述

linux routing kernel linux-networking policy-routing
  • 1 1 个回答
  • 254 Views

1 个回答

  • Voted
  1. Best Answer
    A.B
    2020-01-28T15:05:25+08:002020-01-28T15:05:25+08:00

    没有一般的解释,只是遵循路由设置中发生的事情。

    10.251.0.1 既是本地路由器地址,也是 10.251.0.0/16 的一部分。

    当接收到本地地址的数据包时,路由器使用第一个具有最低优先级的本地表匹配本地ip rule表:0,在表 10 的规则之前,并匹配。请记住,路由表匹配目标,而自定义规则通常配置为匹配源。

    当路由器回复时,这一次本地表不匹配: 10.251.0.2 is not a local destination。检查下一条规则并匹配from 10.251.0.0/16,查找表 10,数据包通过wg1。

    对于 192.168.0.1,接收数据包与之前使用本地表完全一样。现在答案与附加规则不匹配,并且主路由表适用:它照常工作:Linux 系统将从其任何 IP 应答。

    同样,对于 192.168.0.2:它不是本地IP,因此与本地表不匹配,但查询与添加的规则匹配:数据包通过wg1丢失。

    因此,将主路由表的一部分复制到额外的表以避免副作用会有所帮助。

    ip route get只要不涉及任何标记,就可以使用正确的语法来测试其中的许多内容:

    没有表 10 中的附加条目:

    # ip route get from 10.251.0.2 iif eth1.251 10.251.0.1
    RTNETLINK answers: Invalid cross-device link
    # sysctl -w net.ipv4.conf.eth1/251.rp_filter=2 #relax reverse path filtering
    # ip route get from 10.251.0.2 iif eth1.251 10.251.0.1
    local 10.251.0.1 from 10.251.0.2 dev lo table local 
        cache <local> iif eth1.251 
    
    # ip route get from 10.251.0.2 iif eth1.251 192.168.0.1
    local 192.168.0.1 from 10.251.0.2 dev lo table local 
        cache <local> iif eth1.251 
    # ip route get from 10.251.0.2 iif eth1.251 192.168.0.2
    192.168.0.2 from 10.251.0.2 dev wg1 table 10 
        cache iif eth1.251 
    

    回复路线:

    # ip route get from 10.251.0.1 10.251.0.2
    10.251.0.2 from 10.251.0.1 dev wg1 table 10 uid 0 
        cache 
    # ip route get from 192.168.0.1 10.251.0.2
    10.251.0.2 from 192.168.0.1 dev eth1.251 uid 0 
        cache 
    

    添加表 10 中的条目时:

    # ip route get from 10.251.0.2 iif eth1.251 10.251.0.1 #even with strict reverse path filtering, since the reverse route is correct
    local 10.251.0.1 from 10.251.0.2 dev lo table local 
        cache <local> iif eth1.251 
    # ip route get from 10.251.0.1 10.251.0.2
    10.251.0.2 from 10.251.0.1 dev eth1.251 table 10 uid 0 
        cache 
    
    • 2

相关问题

  • 多操作系统环境的首选电子邮件客户端

  • 你最喜欢的 Linux 发行版是什么?[关闭]

  • 更改 PHP 的默认配置设置?

  • 保护新的 Ubuntu 服务器 [关闭]

  • (软)Ubuntu 7.10 上的 RAID 6,我应该迁移到 8.10 吗?

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    新安装后 postgres 的默认超级用户用户名/密码是什么?

    • 5 个回答
  • Marko Smith

    SFTP 使用什么端口?

    • 6 个回答
  • Marko Smith

    命令行列出 Windows Active Directory 组中的用户?

    • 9 个回答
  • Marko Smith

    什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同?

    • 3 个回答
  • Marko Smith

    如何确定bash变量是否为空?

    • 15 个回答
  • Martin Hope
    Tom Feiner 如何按大小对 du -h 输出进行排序 2009-02-26 05:42:42 +0800 CST
  • Martin Hope
    Noah Goodrich 什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同? 2009-05-19 18:24:42 +0800 CST
  • Martin Hope
    Brent 如何确定bash变量是否为空? 2009-05-13 09:54:48 +0800 CST
  • Martin Hope
    cletus 您如何找到在 Windows 中打开文件的进程? 2009-05-01 16:47:16 +0800 CST

热门标签

linux nginx windows networking ubuntu domain-name-system amazon-web-services active-directory apache-2.4 ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve