linux内核多长时间删除一个arp表项 arp 黑洞

如何设置为什么旧的 arp 表项一直没有老化呢?

1. 缩短基础可达时间到 5 秒(实际波动在 2.5s~7.5s)

sysctl -w net.ipv4.neigh.default.base_reachable_time_ms=5000

2. 缩短陈旧条目保留时间到 5 秒

sysctl -w net.ipv4.neigh.default.gc_stale_time=5

3. 提高扫描频率到 2 秒一次

sysctl -w net.ipv4.neigh.default.gc_interval=2

原来还与如下参数(net.ipv4.neigh.default.gc_thresh1)有关

net.ipv4.neigh.default.gc_thresh1 = 2048

net.ipv4.neigh.default.gc_thresh2 = 4096

net.ipv4.neigh.default.gc_thresh3 = 8192

1. gc_thresh1:决定了删除的"积极性"

这是对您影响最大的参数。

  • 逻辑:如果当前 ARP 条目总数 小于 gc_thresh1 (2048),内核的垃圾回收器(GC)会认为内存非常充裕,处于"休眠"状态。
  • 后果:即使条目已经达到了 gc_stale_time(60秒)的老化条件,内核也完全不会去清理它。这些条目会一直留在 STALE 状态,直到条目总数超过 2048。
  • 结论:在您的 80 个 Pod 压测环境下,条目看起来永远不会老化删除,因为总数远达不到 2048。

2. gc_thresh2 和 gc_thresh3:决定了强制清理的频率

这两个参数只有在网络规模极大时才起作用:

  • gc_thresh2 (4096):一旦超过这个值,内核会每隔 5 秒强制启动一次清理。
  • gc_thresh3 (8192):一旦超过这个值,内核会在分配新条目前同步进行强制清理,速度最快,但也最消耗 CPU。

3. 真正控制"老化速度"的参数是谁?

如果您想让 ARP 老化得更快(比如从 REACHABLE 变到 STALE 再到消失),您应该调整以下参数:

  • 状态切换速度:由 base_reachable_time_ms 决定(默认 30s)。
  • 陈旧等待时间:由 gc_stale_time 决定(默认 60s)。
  • 物理删除动作:由 gc_thresh1 决定。
相关推荐
南京码讯光电技术有限公司9 小时前
工业无线AP选型指南:从WiFi 5到WiFi 6+5G CPE,如何构建全覆盖、零漫游、高可靠的智能工厂网络?
服务器·网络·5g
sulikey10 小时前
个人Linux操作系统学习笔记2 - gcc与库的理解
linux·笔记·学习·操作系统·gcc·
二宝哥10 小时前
Linux虚拟机网络配置
linux·运维·服务器
卧室小白10 小时前
docker网络与服务编排与集群
运维·docker·容器
陳103010 小时前
Linux:进程间通信 和 简单进程池
linux·运维·服务器
数字化顾问11 小时前
(122页PPT)数字化架构的演进和治理(附下载方式)
java·运维·架构
jimy111 小时前
改.bashrc,直观地判断本地repo是否有改动
linux·服务器
zt1985q11 小时前
本地部署网页监控工具 Webmonitor 并实现外部访问
运维·服务器·网络·网络协议
愚昧之山绝望之谷开悟之坡11 小时前
什么是Linter?什么是沙箱!
linux·笔记
babytiger12 小时前
Gitea 重安装 + Snap 数据迁移完整流程总结
linux·elasticsearch·gitea