4.1 引言
数据链路如以太网或令牌环网都有自己的寻址机制(常常为48 bit地址),这是使用数据链路的任何网络层都必须遵从的。当一台主机把以太网数据帧发送到位于同一局域网上的另一台主机时,是根据48 bit的以太网地址来确定目的接口的。
4.2 一个例子
任何时候我们敲入下面这个形式的命令:
% ftp bsdi
都会进行以下这些步骤。这些步骤的序号如图4 - 2所示。
- 应用程序FTP客户端调用函数g e t h o s t b y n a m e(3)把主机名(bsdi)转换成32 bit的IP地址。
这个函数在DNS(域名系统)中称作解析器,我们将在第1 4章对它进行介绍。这个转换
过程或者使用DNS,或者在较小网络中使用一个静态的主机文件(/etc/hosts) - FTP客户端请求TCP用得到的IP地址建立连接。
- TCP发送一个连接请求分段到远端的主机,即用上述IP地址发送一份IP数据报(在第
1 8章我们将讨论完成这个过程的细节)。 - 如果目的主机在本地网络上(如以太网、令牌环网或点对点链接的另一端),那么IP数
据报可以直接送到目的主机上。如果目的主机在一个远程网络上,那么就通过IP选路
函数来确定位于本地网络上的下一站路由器地址,并让它转发IP数据报。在这两种情
况下,IP数据报都是被送到位于本地网络上的一台主机或路由器。 - 假定是一个以太网,那么发送端主机必须把32 bit的IP地址变换成48 bit的以太网地址。从逻辑internet地址到对应的物理硬件地址需要进行翻译。这就是ARP的功能。ARP本来是用于广播网络的,有许多主机或路由器连在同一个网络上。
- ARP发送一份称作ARP请求的以太网数据帧给以太网上的每个主机。这个过程称作广
播,如图4 - 2中的虚线所示。ARP请求数据帧中包含目的主机的IP地址(主机名为
bsdi),其意思是“如果你是这个IP地址的拥有者,请回答你的硬件地址。”
4.3 ARP高速缓存
ARP高效运行的关键是由于每个主机上都有一个ARP高速缓存。这个高速缓存存放了最
近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
4.4 ARP的分组格式
- 以太网帧类型表示后面数据的类型。对于ARP请求或应答来说,该字段的
值为0x0806。 - 硬件类型字段表示硬件地址的类型。它的值为1即表示以太网地址。协议类型字段表示要
映射的协议地址类型。它的值为0x0800即表示IP地址。它的值与包含IP数据报的以太网数据
帧中的类型字段的值相同,这是有意设计的(参见图2 - 1) - 硬件地址长度和协议地址长度分别指出硬件地址和协议地址
的长度,以字节为单位。对于以太网上IP地址的ARP请求或应答来说,它们的值分别为6和4。 - 操作字段指出四种操作类型,它们是ARP请求(值为1)、ARP应答(值为2)、RARP请求
(值为3)和RARP应答(值为4)(我们在第5章讨论RARP) - 接下来的四个字段是发送端的硬件地址(在本例中是以太网地址)、发送端的协议地址(IP地址)、目的端的硬件地址和目的端的协议地址。注意,这里有一些重复信息:在以太网的数据帧报头中和ARP请求数据帧中都有发送端的硬件地址。
对于一个ARP请求来说,除目的端硬件地址外的所有其他的字段都有填充值。当系统收到一份目的端为本机的ARP请求报文后,它就把硬件地址填进去,然后用两个目的端地址分别替换两个发送端地址,并把操作字段置为2,最后把它发送回去。
4.5 ARP配置
一般情况下,当系统收到ARP请求或发送ARP应答时,都要把请求端的硬件地址和I P地
址存入ARP高速缓存。在逻辑上可以假设,如果请求端要发送IP数据报,那么数据报的接收
端将很可能会发送一个应答。
4.6 ARP代理
如果ARP请求是从一个网络的主机发往另一个网络上的主机,那么连接这两个网络的路
由器就可以回答该请求,这个过程称作委托ARP或ARP代理(Proxy ARP)。这样可以欺骗发起
ARP请求的发送端,使它误以为路由器就是目的主机,而事实上目的主机是在路由器的“另
一边”。路由器的功能相当于目的主机的代理,把包从其他主机转发给它。