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 决定。
相关推荐
大树888 小时前
金刚石散热越强,管路越先见顶
大数据·运维·服务器·人工智能·ai
摇滚侠8 小时前
Linux CentOS7 rpm 安装 MySQL 5.7
linux·运维·mysql
霸道流氓气质8 小时前
领域驱动设计(DDD)在 Spring Boot 微服务中的实践指南
运维·spring boot·微服务
bush48 小时前
嵌入式linux学习记录十四、术语
linux·嵌入式
载数而行5208 小时前
Linux 11 动态监控指令top
linux
小宇宙Zz8 小时前
Maven依赖冲突
java·服务器·maven
Inhand陈工9 小时前
基于台达PLC与映翰通IG502的智慧水产养殖精准投喂与远程运维解决方案
运维·人工智能·物联网·阿里云·信息与通信
酣大智9 小时前
ARP代理--工作原理
运维·网络·arp·arp代理
不会C语言的男孩10 小时前
Linux 系统编程 · 第 8 章:进程基础
linux·c语言
shushangyun_10 小时前
2026年快消品B2B系统推荐:支持终端门店订货、促销政策自动化的工具?
java·运维·网络·数据库·人工智能·spring·自动化