ARP:地址解析协议

ARP:地址解析协议

一个例子

任何时候我们敲入下面这个形式的命令:

% ftp bsdi

都会进行以下这些步骤。这些步骤的序号如图 4-2所示。

  1. 应用程序FTP客户端调用函数 gethostbyname把主机名(bsdi)转换成32 bit的IP地址。这个函数在DNS(域名系统)中称作解析器,这个转换过程或者使用DNS,或者在较小网络中使用一个静态的主机文件(/etc/hosts)。
  2. FTP客户端请求TCP用得到的I P地址建立连接。
  3. TCP发送一个连接请求分段到远端的主机,即用上述 IP地址发送一份 I P数据报。
  4. 如果目的主机在本地网络上(如以太网、令牌环网或点对点链接的另一端),那么IP数据报可以直接送到目的主机上。如果目的主机在一个远程网络上,那么就通过 IP选路函数来确定位于本地网络上的下一站路由器地址,并让它转发 I P数据报。在这两种情况下,IP数据报都是被送到位于本地网络上的一台主机或路由器。
  5. 假定是一个以太网,那么发送端主机必须把 32 bit的I P地址变换成48 bit的以太网地址。从逻辑Internet地址到对应的物理硬件地址需要进行翻译。这就是 ARP的功能。ARP本来是用于广播网络的,有许多主机或路由器连在同一个网络上。
  6. ARP发送一份称作 ARP请求的以太网数据帧给以太网上的每个主机。这个过程称作广播,如图 4-2 中的虚线所示。 ARP请求数据帧中包含目的主机的 IP地址(主机名为bsdi),其意思是“如果你是这个 I P地址的拥有者,请回答你的硬件地址。”


图4-2 当用户输入命令“ftp 主机名”时ARP的操作

  1. 目的主机的ARP层收到这份广播报文后,识别出这是发送端在寻问它的 IP地址,于是
    发送一个ARP应答。这个ARP应答包含I P地址及对应的硬件地址。
  2. 收到ARP应答后,使ARP进行请求—应答交换的I P数据报现在就可以传送了。
  3. 发送IP数据报到目的主机。

在ARP背后有一个基本概念,那就是网络接口有一个硬件地址(一个 48 bit的值,标识不同的以太网或令牌环网络接口)。在硬件层次上进行的数据帧交换必须有正确的接口地址。但是,TCP/IP有自己的地址:32 bit的I P地址。知道主机的I P地址并不能让内核发送一帧数据给主机。内核(如以太网驱动程序)必须知道目的端的硬件地址才能发送数据。 ARP的功能是在32 bit的I P地址和采用不同网络技术的硬件地址之间提供动态映射。

点对点链路不使用ARP。当设置这些链路时(一般在引导过程进行),必须告知内核链路每一端的IP地址。像以太网地址这样的硬件地址并不涉及。

ARP高速缓存

A R P高效运行的关键是由于每个主机上都有一个 A R P高速缓存。这个高速缓存存放了最近Internet地址到硬件地址之间的映射记录。高速缓存中每一项的生存时间一般为 20分钟,起始时间从被创建时开始算起。

我们可以用arp命令来检查ARP高速缓存。参数-a的意思是显示高速缓存中所有的内容。

bsdi % arp -a
sun (140.252.13.33) at 8:0:20:3:f6:42
svr4 (140.252.13.34) at 0:0:c0:c2:9b:26

48 bit的以太网地址用 6个十六进制的数来表示,中间以冒号隔开。在 4.8小节我们将讨论arp命令的其他功能。

ARP的分组格式

在以太网上解析 IP 地址时,ARP请求和应答分组的格式如图 4-3所示(ARP可以用于其他类型的网络,可以解析 I P地址以外的地址。紧跟着帧类型字段的前四个字段指定了最后四个字段的类型和长度)


图4-3 用于以太网的ARP请求或应答分组格式

ARP代理

如果ARP请求是从一个网络的主机发往另一个网络上的主机,那么连接这两个网络的路由器就可以回答该请求,这个过程称作委托 ARP 或 ARP 代理(Proxy ARP)。这样可以欺骗发起 ARP 请求的发送端,使它误以为路由器就是目的主机,而事实上目的主机是在路由器的“另一边”。路由器的功能相当于目的主机的代理,把分组从其他主机转发给它。