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 / 问题 / 1083698
Accepted
roelvanmeer
roelvanmeer
Asked: 2021-11-17 04:07:23 +0800 CST2021-11-17 04:07:23 +0800 CST 2021-11-17 04:07:23 +0800 CST

Linux:是什么导致静态 ARP 条目在链路断开时刷新

  • 772

这是一个关于Debian Buster(内核 4.19.0-18)和Debian Bullseye(内核 5.10.0-9)之间网络行为差异的问题。在 Buster 上,如果接口上的链接断开,代理 arp 条目将继续存在。在 Bullseye 上,他们没有。

情况:在特定接口上创建静态代理 ARP 条目:

ip neigh add proxy 1.2.3.5 dev eth0

我可以验证该条目是否存在:

ip neigh show proxy

现在,如果该接口上的链接断开并再次恢复,则在 Buster 上,代理 arp 条目仍然存在,在 Bullseye 上它们消失了。

我想知道这种差异背后的原因。它是内核功能吗?udev 是这样做的吗?是否有一个 sysctl 设置来管理这个?

有人能指出我正确的方向吗?如果您知道如何在 Bullseye / 内核 5.10 上创建静态 ARP 条目,那就更好了。

请注意,我使用的是 sysvinit,而不是 systemd。谢谢!

arp linux-networking iproute2
  • 1 1 个回答
  • 561 Views

1 个回答

  • Voted
  1. Best Answer
    A.B
    2021-11-17T16:03:16+08:002021-11-17T16:03:16+08:00

    以下是与此问题相关的更改历史记录:

    • 2018-10-12 09:47:39 -0700

      net:驱逐运营商关闭的邻居条目

      在 netdev -next 树上提交:这负责在链路使运营商关闭时删除邻居条目,并在提交消息中提供基本原理。

    • 2018-10-22 07:47:45 +0100

      内核 v4.19 发布。

      这仍然不包括来自 netdev -next 分支的提交。

    • 2018-10-24 06:47:44 +0100

      Davem 的合并请求(包括先前的邻居更改)被合并到 linux master 中,因此一旦发布就包含在 linux v4.20中。

    快进……

    • 2021-11-01 19:57:14 -0700 + 2021-11-01 19:57:17 -0700

      net: arp: 引入arp_evict_nocarriersysctl 参数

      此更改引入了一个新的 sysctl 参数arp_evict_nocarrier. 当设置(默认)时,ARP 缓存将在NOCARRIER事件中被清除。此新选项已默认为“1”,以保持现有行为。
      [...]

    因此,您可能必须等待靶心反向移植中的内核 >= 5.16 才能通过执行 then 来恢复旧行为,例如:

    sysctl -w net.ipv4.conf.eth0.arp_evict_nocarrier=0
    

    或等待稍后的一些调整使代理条目表现得像永久条目(使特定代码不受运营商停机事件的影响)。


    关于第二个问题“如何创建静态 ARP 条目”,这里是在接口eth0上添加 MAC 地址为 12:34:56:78:9a:bc 的 192.0.2.2 的静态条目的方法,使用replace关键字而不是add关键字这可能会随机返回一个RTNETLINK answers: File exists error(或change会遭受相反的影响):

    ip neigh replace 192.0.2.2 dev eth0 lladdr 12:34:56:78:9a:bc nud permanent
    
    • 2

相关问题

  • Cisco WS-C6509-E Arp 缓存损坏问题?

  • Ubuntu Linux - 多个 NIC,同一个 LAN ... ARP 响应总是从一个 NIC 发出

  • 如何获取 LAN 上所有 IP 地址(以及理想的设备名称)的列表?

  • 是否可以将内部 IP 地址与交换机端口匹配?

  • 如何预防/检测 ARP 毒根攻击?

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