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
    • 最新
    • 标签
主页 / computer / 问题 / 1834516
Accepted
discape
discape
Asked: 2024-03-11 01:53:12 +0800 CST2024-03-11 01:53:12 +0800 CST 2024-03-11 01:53:12 +0800 CST

什么决定数据包应该在本地路由还是转发?

  • 772

Linux数据包流

如图所示,当 Linux 内核收到数据包时,它会经过预路由链,然后做出路由决策,决定是否将其转发到其他地方或将其传递到本地进程。

  • 输入接口的IP地址如何影响路由决策?

  • 其他接口的 IP 地址如何影响路由决策?

  • 路由表如何影响路由决策?

  • 是否有任何好的资源来描述内核如何做出此入站路由决策?

我想要实现的目标是将目标地址为 95.123.123.62 的 eno1 数据包转发到 virbr0(libvirtd虚拟网络交换机)。然而,它们似乎只是被放入输入链中,即使目标 IP 属于 virbr0 接口。这是输出ip address:

83: virbr0: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue state UP group default qlen 1000
    link/ether 52:54:00:39:d0:49 brd ff:ff:ff:ff:ff:ff
    inet 192.168.122.1/24 brd 192.168.122.255 scope global virbr0
       valid_lft forever preferred_lft forever
    inet 95.123.123.62/32 scope global virbr0 
       valid_lft forever preferred_lft forever
2: eno1: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc fq_codel state UP group default qlen 1000                                                                                   
    link/ether 30:9c:23:b8:c2:08 brd ff:ff:ff:ff:ff:ff                                                                                                                                
    altname enp0s31f6                                                                                                                                                                 
    inet 95.123.123.20/26 brd 95.216.225.63 scope global eno1                                                                                                                         
       valid_lft forever preferred_lft forever                
linux
  • 2 2 个回答
  • 14 Views

2 个回答

  • Voted
  1. Best Answer
    u1686_grawity
    2024-03-11T02:06:19+08:002024-03-11T02:06:19+08:00

    路由表如何影响路由决策?

    在内部,都是根据路由表制定的。Linux 有一个额外的路由表,local该表具有属于同一系统的地址的特殊路由:

    $ ip route ls table local
    local 10.147.241.1 dev mlx0 proto kernel scope host
    

    其内容是根据分配给接口的 IP 地址自动生成的。在极少数情况下,您可能想要创建此类路由或直接调整此表,而您的情况似乎并非如此 - 相反,您一开始就不应该将此地址分配给接口。

    这些表被挂接到“策略路由”系统中:

    $ ip rule
    0:      from all lookup local
    32766:  from all lookup main
    

    我想要实现的目标是将目标地址为 95.123.123.62 的 eno1 数据包转发到 virbr0,这是一个 libvirtd 虚拟网络交换机。然而,它们似乎只是被放入输入链中,即使目标 ip 属于 virbr0 接口

    这正是数据包进入输入链的原因 - 因为它们属于本地接口。

    通常,所配置子网的其他地址(例如,除192.168.122.1 之外的整个 192.168.122.0/24)将通过接口转发,而所配置的地址本身根据定义是本地的。

    因此,将地址分配给 virbr0 作为 /32 具有与您所要求的完全相反的效果:它表明该地址是本地地址,因此根据定义不会转发到任何其他地方。

    如果具有该地址的虚拟机应该直接连接到网桥的另一端,则需要添加一条路由:

    ip addr del 95.123.123.62/32 dev virbr0
    ip route add 95.123.123.62/32 dev virbr0
    

    没有网关的路由实际上就像“本地子网”路由一样工作 - 主机将尝试为具有该地址的(虚拟)机器进行 ARP。

    • 1
  2. discape
    2024-03-11T02:06:00+08:002024-03-11T02:06:00+08:00

    我在 Unix & Linux 上找到了这个答案,解释了路由规则。基于此,似乎

    1. 如果任何接口有目标 IP,则数据包将路由到本地进程。IP 可以属于不同的接口,所以这就是它只是在本地路由的原因,尽管看起来有点奇怪。
    2. 否则,使用主路由表。
    • 0

相关问题

  • 如何让我的 Linux 机器看起来像是在运行 Windows?

  • 对于 cp 或 mv,是否有等同于 cd - 的东西?

  • 以 root 身份运行 docker 容器

  • 如何在域和 Linux 活动目录中启用指纹传感器

  • 如何在CentOS 7 中将Ctrl+C 永久更改为Ctrl+K?

Sidebar

Stats

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

    如何减少“vmmem”进程的消耗?

    • 11 个回答
  • Marko Smith

    从 Microsoft Stream 下载视频

    • 4 个回答
  • Marko Smith

    Google Chrome DevTools 无法解析 SourceMap:chrome-extension

    • 6 个回答
  • Marko Smith

    Windows 照片查看器因为内存不足而无法运行?

    • 5 个回答
  • Marko Smith

    支持结束后如何激活 WindowsXP?

    • 6 个回答
  • Marko Smith

    远程桌面间歇性冻结

    • 7 个回答
  • Marko Smith

    子网掩码 /32 是什么意思?

    • 6 个回答
  • Marko Smith

    鼠标指针在 Windows 中按下的箭头键上移动?

    • 1 个回答
  • Marko Smith

    VirtualBox 无法以 VERR_NEM_VM_CREATE_FAILED 启动

    • 8 个回答
  • Marko Smith

    应用程序不会出现在 MacBook 的摄像头和麦克风隐私设置中

    • 5 个回答
  • Martin Hope
    Vickel Firefox 不再允许粘贴到 WhatsApp 网页中? 2023-08-18 05:04:35 +0800 CST
  • Martin Hope
    Saaru Lindestøkke 为什么使用 Python 的 tar 库时 tar.xz 文件比 macOS tar 小 15 倍? 2021-03-14 09:37:48 +0800 CST
  • Martin Hope
    CiaranWelsh 如何减少“vmmem”进程的消耗? 2020-06-10 02:06:58 +0800 CST
  • Martin Hope
    Jim Windows 10 搜索未加载,显示空白窗口 2020-02-06 03:28:26 +0800 CST
  • Martin Hope
    andre_ss6 远程桌面间歇性冻结 2019-09-11 12:56:40 +0800 CST
  • Martin Hope
    Riley Carney 为什么在 URL 后面加一个点会删除登录信息? 2019-08-06 10:59:24 +0800 CST
  • Martin Hope
    zdimension 鼠标指针在 Windows 中按下的箭头键上移动? 2019-08-04 06:39:57 +0800 CST
  • Martin Hope
    jonsca 我所有的 Firefox 附加组件突然被禁用了,我该如何重新启用它们? 2019-05-04 17:58:52 +0800 CST
  • Martin Hope
    MCK 是否可以使用文本创建二维码? 2019-04-02 06:32:14 +0800 CST
  • Martin Hope
    SoniEx2 更改 git init 默认分支名称 2019-04-01 06:16:56 +0800 CST

热门标签

windows-10 linux windows microsoft-excel networking ubuntu worksheet-function bash command-line hard-drive

Explore

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

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve