ARP代理--工作原理

ARP 代理(Proxy ARP)工作原理详解:

ARP代理作用:arp代理可以让IP地址属于同一网段却不属于同一物理网络的主机间相互通信。

例子,如图所示:

开启代理之前PC1>ping 10.1.2.2不通;

开启代理之前PC1>ping 10.1.2.2可以通;

配置命令如下:

int g0/0/1

arp-proxy enable

int g0/0/2

arp-proxy enable

其他相关命令:

arp -a 查看PC机的ARP缓存表

arp -s 在PC机上绑定IP地址和MAC地址

实验结果的详细分析过程:

一、为什么需要 ARP 代理?

在您的拓扑中存在一个关键矛盾

设备 IP 地址 / 掩码 自身判断 实际网络情况
PC1 10.1.1.2/16 认为自己在 10.1.0.0/16 网段,PC2 (10.1.2.2) 和自己同网段 实际在左子网 10.1.1.0/24
PC2 10.1.2.2/16 认为自己在 10.1.0.0/16 网段,PC1 (10.1.1.2) 和自己同网段 实际在右子网 10.1.2.0/24
AR1 两个接口都是 / 24 知道两个子网是不同物理网络 路由器隔开了两个广播域

核心问题:两台主机都认为对方在同一广播域,会直接发 ARP 请求,但路由器默认不转发广播包,ARP 请求无法跨子网到达。


二、完整通信过程(PC1 ping PC2)

阶段 1:PC1 发起 ARP 请求
  1. PC1 计算:10.1.2.2 & 255.255.0.0 = 10.1.0.0,与自己同网段

  2. PC1 发送广播 ARP 请求

    复制代码
    源MAC: PC1_MAC
    目的MAC: FF:FF:FF:FF:FF:FF(广播)
    内容:"谁是10.1.2.2?请告诉10.1.1.2"
  3. 广播包到达 AR1 的 GE0/0/1 接口

阶段 2:路由器 ARP 代理响应
  1. AR1 收到 ARP 请求,检查:

    • 目的 IP 10.1.2.2 不在 GE0/0/1 所在的 10.1.1.0/24 网段
    • 查找路由表,发现 10.1.2.0/24 在 GE0/0/2 接口可达
    • 确认自己开启了 ARP 代理功能
  2. AR1 以自己的 MAC 地址代答 ARP 请求(这就是代理!):

    复制代码
    源MAC: AR1_GE0/0/1_MAC
    目的MAC: PC1_MAC
    内容:"10.1.2.2的MAC地址是 AR1_GE0/0/1_MAC"
阶段 3:PC1 发送数据
  1. PC1 收到 ARP 响应,在 ARP 表中记录:

    复制代码
    10.1.2.2 → AR1_GE0/0/1_MAC
  2. PC1 将 ICMP 数据包发给路由器(以为直接发给 PC2):

    复制代码
    源MAC: PC1_MAC
    目的MAC: AR1_GE0/0/1_MAC
    源IP: 10.1.1.2
    目的IP: 10.1.2.2
阶段 4:路由器转发 + PC2 侧 ARP 代理
  1. AR1 解封装,查路由表,将数据包从 GE0/0/2 转发出去
  2. 同样的过程在 PC2 侧重复:PC2 发 ARP 请求找 10.1.1.2,AR1 用 GE0/0/2 的 MAC 代答
  3. 双向通信建立完成

三、ARP 代理的本质

ARP 代理 = 路由器 "欺骗" 主机

  • 对 PC1:路由器假装自己是 PC2
  • 对 PC2:路由器假装自己是 PC1
  • 两台主机都以为在直接通信,实际所有流量都经过路由器转发

ARP 表最终状态

复制代码
PC1 ARP表:10.1.2.2 → AR1_GE0/0/1_MAC
PC2 ARP表:10.1.1.2 → AR1_GE0/0/2_MAC

四、典型应用场景

  1. 主机使用大掩码(如您的拓扑):/16 掩码但实际划分了多个 / 24 子网
  2. 无默认网关的主机:某些设备不支持配置网关,靠 ARP 代理访问其他子网
  3. VPN / 专线场景:跨广域网的两个站点使用同网段地址
  4. 迁移过渡期:网络改造中 IP 规划变更的过渡方案

五、华为设备配置命令

复制代码
[AR1] interface GigabitEthernet 0/0/1
[AR1-GigabitEthernet0/0/1] arp-proxy enable  # 开启接口ARP代理

[AR1] interface GigabitEthernet 0/0/2
[AR1-GigabitEthernet0/0/2] arp-proxy enable

注意:ARP 代理默认关闭,需要在路由器的两个接口上都开启才能正常工作。

相关推荐
Inhand陈工1 小时前
基于台达PLC与映翰通IG502的智慧水产养殖精准投喂与远程运维解决方案
运维·人工智能·物联网·阿里云·信息与通信
网络研究院2 小时前
2026年网络安全
网络·安全·法律·法规·趋势·发展
treesforest2 小时前
AI安全系统如何识别异常访问?IP风险识别正在成为关键能力
网络·人工智能·tcp/ip·安全·web安全
shushangyun_2 小时前
2026年快消品B2B系统推荐:支持终端门店订货、促销政策自动化的工具?
java·运维·网络·数据库·人工智能·spring·自动化
2601_961845152 小时前
粉笔行测题库|系统班|刷题
网络·百度·微信·微信公众平台·facebook·新浪微博
施努卡机器视觉3 小时前
SNK施努卡侧滑门锁上滑轮总成自动化装配线,从零件到组件,全流程精密制造方案
运维·自动化·制造
程序猿阿伟3 小时前
《Chrome离线扩展安装的底层逻辑与场景落地指南》
服务器·网络·chrome
InHand云飞小白3 小时前
无人值守站点网络困境?工业级路由器IR315破解连接难题
网络·物联网·4g·工业路由器·4g路由器·iiot·蜂窝路由器
AC赳赳老秦3 小时前
用 OpenClaw 搭建服务器故障应急响应系统,自动处理 80% 常见运维故障
android·运维·服务器·python·rxjava·deepseek·openclaw