1. 引言
在计算机网络通信中,IP地址和MAC地址是两个最核心的概念。IP地址用于标识网络中的主机,而MAC地址则用于在物理网络中唯一标识一个网络接口。然而,当数据包从一台主机发送到另一台主机时,网络层(IP层)只知道目标IP地址,而数据链路层(如以太网)则需要目标MAC地址才能真正完成数据传输。那么,如何根据IP地址找到对应的MAC地址呢?这就是**ARP(Address Resolution Protocol,地址解析协议)**的核心任务。
本文将详细介绍ARP协议的作用、工作原理、报文格式、缓存机制以及相关安全问题,帮助读者深入理解ARP在局域网通信中的关键作用。
2. ARP协议的作用
2.1 IP地址与MAC地址的关系
在TCP/IP协议栈中:
- IP地址(逻辑地址):用于网络层(Layer 3),标识主机在网络中的位置,可动态分配(如DHCP)。
- MAC地址(物理地址) :用于数据链路层(Layer 2),固化在网卡中,全球唯一(如
00:1A:2B:3C:4D:5E
)。
数据包在传输过程中,网络层使用IP地址进行路由选择,但最终必须转换成MAC地址才能在物理网络中传输。因此,ARP的作用就是动态地将IP地址映射到MAC地址 。
2.2 ARP的应用场景
ARP主要用于**局域网(LAN)**内通信,例如:
- 主机A(IP:
192.168.1.2
)想与主机B(IP:192.168.1.3
)通信,但不知道B的MAC地址。 - 路由器在转发数据包时,需要知道下一跳的MAC地址。
- 设备刚接入网络时,需要获取网关的MAC地址。
如果没有ARP,主机之间就无法直接通信,必须手动维护IP-MAC映射表(显然不现实)。
3. ARP的工作流程
ARP的工作过程可以分为以下几个步骤:
3.1 检查本地ARP缓存
在发送数据之前,主机会先查询自己的ARP缓存表(存储IP-MAC映射),以减少不必要的ARP请求。
- 如果缓存中有目标IP的MAC地址,则直接使用该地址封装数据帧。
- 如果缓存中没有目标IP的MAC地址,则进入ARP请求阶段。
3.2 发送ARP请求(广播)
主机A构造一个ARP请求报文,包含:
- 发送端IP和MAC地址(源信息)。
- 目标IP地址(待解析的地址)。
- 目标MAC地址 初始为全
FF:FF:FF:FF:FF:FF
(广播地址)。
该ARP请求以广播方式发送到局域网内的所有设备(交换机或集线器会转发到所有端口)。
3.3 接收ARP响应(单播)
局域网内的所有主机都会收到这个ARP请求,并检查:
- 如果目标IP与自身不匹配:丢弃该请求。
- 如果目标IP与自身匹配 (例如主机B的IP是
192.168.1.3
):- 主机B将主机A的IP-MAC映射存入自己的ARP缓存。
- 主机B构造ARP响应报文(单播),包含自己的MAC地址。
- 主机B将该响应直接发送给主机A(不再广播)。
3.4 更新ARP缓存并通信
- 主机A收到ARP响应后,将主机B的IP-MAC映射存入本地ARP缓存(通常有生存时间TTL,如20分钟)。
- 后续通信直接使用缓存的MAC地址封装数据帧,无需再次ARP请求。
4. ARP报文格式
ARP协议的报文封装在以太网帧中,格式如下:
字段 | 长度(字节) | 说明 |
---|---|---|
硬件类型 | 2 | 网络类型(如以太网=1) |
协议类型 | 2 | 上层协议(如IPv4=0x0800) |
硬件地址长度 | 1 | MAC地址长度(通常6) |
协议地址长度 | 1 | IP地址长度(通常4) |
操作码 | 2 | 1=ARP请求,2=ARP响应 |
发送端MAC地址 | 6 | 发送方的MAC地址 |
发送端IP地址 | 4 | 发送方的IP地址 |
目标MAC地址 | 6 | 目标MAC地址(请求时为全F) |
目标IP地址 | 4 | 目标IP地址 |
示例:
- ARP请求 :
opcode=1
,目标MAC=FF:FF:FF:FF:FF:FF
。 - ARP响应 :
opcode=2
,目标MAC=实际MAC地址。
5. ARP缓存机制
为了提高效率,ARP采用缓存机制:
- 动态缓存:通过ARP请求/响应自动学习,TTL通常为几分钟到几小时。
- 静态缓存 :管理员手动配置(如
arp -s
命令),永久有效(除非重启)。
查看ARP缓存(Windows/Linux):
sh
# Windows
arp -a
# Linux
arp -n

6. ARP的局限性及安全问题
6.1 ARP欺骗(ARP Spoofing)
由于ARP协议无身份验证机制,攻击者可以伪造ARP响应,欺骗目标主机更新错误的IP-MAC映射,导致:
- 中间人攻击(MITM):攻击者劫持通信流量。
- DoS攻击:使目标主机无法正常通信。
防御方法:
- 静态ARP绑定:手动设置关键设备的IP-MAC映射。
- ARP防火墙:检测异常ARP流量。
- 网络隔离:使用VLAN限制广播域。

6.2 跨网络通信
ARP仅适用于同一局域网,跨网络通信时:
- 主机会先请求网关的MAC地址(通过ARP)。
- 网关(路由器)负责将数据包转发到目标网络。
7. 总结
- ARP的作用:动态解析IP地址到MAC地址,使局域网内主机能够直接通信。
- 工作流程 :
- 检查ARP缓存。
- 若无缓存,广播ARP请求。
- 目标主机单播响应。
- 更新缓存并通信。
- 安全问题:ARP欺骗是常见攻击手段,需采取防御措施。
ARP协议虽然简单,但却是局域网通信的基石。理解其原理有助于网络故障排查和安全防护。