ipvsadm vip ARP 响应失败的 arp_ignore / arp_announce 配置

发布时间 - 2026-01-28 00:00:00    点击率:
VIP的ARP响应失败是因为arp_ignore未正确配置;LVS-DR要求Real Server不响应VIP的ARP,需将all和lo接口的arp_ignore均设为1,否则内核默认值0导致lo接口响应ARP。

为什么 VIP 的 ARP 响应失败,和 arp_ignore 有关

Linux 内核默认会响应所有本地 IP(包括绑定在 lo 上的 VIP)的 ARP 请求,这在 LVS-DR 模式下会导致后端 Real Server 主动应答客户端的 ARP 查询,破坏 Director 的流量调度逻辑。关键在于 arp_ignore 控制“谁有资格应答 ARP”。设为 1 表示:仅当目标 IP 配置在请求到达的接口上时才应答;设为 2 表示:只要本机任一接口配置了该 IP 就应答(不推荐用于 DR)。LVS-DR 要求 Real Server 完全不响应 VIP 的 ARP,所以必须设为 1

常见错误是只改了 lo 接口的值,却忘了全局默认值仍为 0 —— 内核优先查接口级配置,查不到就回落到全局,而 lo 默认没定义 arp_ignore,实际生效的是 /proc/sys/net/ipv4/conf/all/arp_ignore。所以必须显式设置:

echo 1 > /proc/sys/net/ipv4/conf/all/arp_ignore
echo 1 > /proc/sys/net/ipv4/conf/lo/arp_ignore

arp_announce 的作用不是“发不发 ARP”,而是“用哪个源地址发”

很多人误以为调高 arp_announce 能阻止 ARP 响应,其实它只影响本机主动发送 ARP 请求(比如地址变更、免费 ARP)时,如何选择源 IP 地址。在 LVS-DR 中,Real Server 需要确保:当它因其他原因(如网关刷新)发出 ARP 请求时,源 IP 不暴露 VIP。因此应设为 2:“总是使用最佳本地地址(即与目标网络匹配的、配置在入接口上的地址)”,避免从 lo 上的 VIP 发出 ARP。

同样需同时设置 all 和 lo:

echo 2 > /proc/sys/net/ipv4/conf/all/arp_announce
echo 2 > /proc/sys/net/ipv4/conf/lo/arp_announce
  • arp_announce=1 仅跳过同子网内其他接口上的地址,不够严格
  • 不设 lo 级配置时,lo 仍按默认 0 行为选源地址,可能泄露 VIP
  • 该参数对被动 ARP 响应无影响,别指望靠它解决“VIP 被抢答”问题

ipvsadm 规则本身不触发 ARP 行为,但依赖正确的内核 ARP 策略

ipvsadm 只负责建立连接跟踪和转发规则,它不干预 ARP 协议栈。哪怕 ipvsadm -Ln 显示服务正常、连接已建立,只要 Real Server 的 arp_ignore 没配对,Director 收到客户端 ARP 请求后,仍可能收到 Real Server 的错误应答,导致客户端把 VIP 解析到 Real Server 的 MAC,绕过 Director。

验证是否生效的关键命令:

ipvsadm -Ln
cat /proc/sys/net/ipv4/conf/all/arp_ignore
cat /proc/sys/net/ipv4/conf/lo/arp_ignore
arping -I eth0 -c 2 

最后一条应在 Director 上执行:若能看到 Real Server 回包,说明其仍在响应 ARP —— 配置未生效或未覆盖 lo 接口。

持久化配置容易漏掉 lo 接口,且 systemd-networkd 可能覆盖 sysctl

写进 /etc/sysctl.confnet.ipv4.conf.all.arp_ignore = 1 会被加载,但 net.ipv4.conf.lo.arp_ignore 很多发行版默认不写,重启后丢失。更隐蔽的问题是:某些系统(如使用 systemd-networkdNetworkManager 的新版 Ubuntu/CentOS)会在接口 up 时重置 conf/lo/ 下的参数,覆盖 sysctl 设置。

稳妥做法:

  • /etc/sysctl.conf 中明确写入 net.ipv4.conf.lo.arp_ignore = 1net.ipv4.conf.lo.arp_announce = 2
  • 添加 systemd service 或

    network script,在 lo up 后再次 echo 这两个值(尤其当使用 cloud-init 或容器环境时)
  • 避免用 sysctl -p 临时加载,它不保证接口级配置被应用到 lo

lo 接口的 ARP 参数不像物理网卡那样有“启动脚本”概念,它的初始化时机特殊,最容易被忽略。


# linux  # centos  # ubuntu  # 后端  # mac  #   # 为什么  # 子网  # echo  # 接口  # lvs  # 设为  # 客户端  # 本机  # 它不  # 默认值  # 的是  # 加载  # 源地址  # 是因为  # 很多人 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: javascript中的数组方法有哪些_如何利用数组方法简化数据处理  Laravel如何升级到最新版本?(升级指南和步骤)  Laravel怎么做数据加密_Laravel内置Crypt门面的加密与解密功能  googleplay官方入口在哪里_Google Play官方商店快速入口指南  青岛网站建设如何选择本地服务器?  如何安全更换建站之星模板并保留数据?  ChatGPT回答中断怎么办 引导AI继续输出完整内容的方法  Midjourney怎样加参数调细节_Midjourney参数调整技巧【指南】  JavaScript中如何操作剪贴板_ClipboardAPI怎么用  东莞市网站制作公司有哪些,东莞找工作用什么网站好?  Laravel如何处理表单验证?(Requests代码示例)  在Oracle关闭情况下如何修改spfile的参数  电视网站制作tvbox接口,云海电视怎样自定义添加电视源?  如何快速打造个性化非模板自助建站?  网页设计与网站制作内容,怎样注册网站?  百度浏览器网页无法复制文字怎么办 百度浏览器复制修复  车管所网站制作流程,交警当场开简易程序处罚决定书,在交警网站查询不到怎么办?  如何用ChatGPT准备面试 模拟面试问答与职场话术练习教程  Laravel如何升级到最新的版本_Laravel版本升级流程与兼容性处理  瓜子二手车官方网站在线入口 瓜子二手车网页版官网通道入口  Laravel如何使用API Resources格式化JSON响应_Laravel数据资源封装与格式化输出  Android滚轮选择时间控件使用详解  Laravel如何操作JSON类型的数据库字段?(Eloquent示例)  nginx修改上传文件大小限制的方法  什么是JavaScript解构赋值_解构赋值有哪些实用技巧  html5的keygen标签为什么废弃_替代方案说明【解答】  如何在HTML表单中获取用户输入并结合JavaScript动态控制复利计算循环  Win11怎么关闭透明效果_Windows11辅助功能视觉效果设置  微信小程序 五星评分(包括半颗星评分)实例代码  如何在阿里云服务器自主搭建网站?  php后缀怎么变mp4格式错误_修改扩展名提示格式不对怎么办【技巧】  济南网站建设制作公司,室内设计网站一般都有哪些功能?  Win11怎么恢复误删照片_Win11数据恢复工具使用【推荐】  Laravel软删除怎么实现_Laravel Eloquent SoftDeletes功能使用教程  晋江文学城电脑版官网 晋江文学城网页版直接进入  文字头像制作网站推荐软件,醒图能自动配文字吗?  nodejs redis 发布订阅机制封装实现方法及实例代码  Laravel如何设置定时任务(Cron Job)_Laravel调度器与任务计划配置  如何快速启动建站代理加盟业务?  南京网站制作费用,南京远驱官方网站?  edge浏览器无法安装扩展 edge浏览器插件安装失败【解决方法】  使用豆包 AI 辅助进行简单网页 HTML 结构设计  在线ppt制作网站有哪些软件,如何把网页的内容做成ppt?  Laravel如何与Pusher实现实时通信?(WebSocket示例)  电商网站制作价格怎么算,网上拍卖流程以及规则?  mc皮肤壁纸制作器,苹果平板怎么设置自己想要的壁纸我的世界?  1688铺货到淘宝怎么操作 1688一键铺货到自己店铺详细步骤  Laravel API资源类怎么用_Laravel API Resource数据转换  JavaScript如何实现继承_有哪些常用方法  手机软键盘弹出时影响布局的解决方法