ARP:地址解析协议
当一台主机把以太网数据帧发送到位于同意局域网上的另一台主机时,是根据48bit的以太网地址来确定目的接口。设备驱动程序从不检查IP数据报中的目的IP地址。
地址解析为这两种不同的地址形式提供映射:32bit的IP地址和数据链路层使用的任何类型的地址。ARP为IP地址到对应的硬件地址之间提供动态映射。
举例说明ARP:
当我们敲入% ftp bsdi 这个命令,会进行以下步骤:
1)应用程序FTP客户端调用函数gethostbyname(3)把主机名(bsdi)转换成32bit的IP地址。这个函数在DNS(域名系统)中称作解析器。
2)FTP客户端请求TCP用得到的IP地址建立连接。
3)TCP发送一个连接请求分段到远端的主机,即用上述IP地址发送一份IP数据报。
4)如果目的主机在本地网络上(如以太网,令牌环网或点对点连接的另一端),那么IP数据报可以直接送到目的主机上。如果目的主机在一个远程网络上,那么就通过IP选路函数来确定位于本地网络上的下一站路由器地址,并让它转发IP数据报。
5)假定是一个以太网,那么发送短主机必须把32bit的IP地址变换成48bit的以太网地址,从逻辑Internet地址到对应的物理硬件地址需要进行翻译。这就是ARP的功能。
6)ARP发送一份称作ARP请求的以太网数据帧给以太网上的每一个主机。这个过程称作广播。
7)目的主机的ARP层收到这份广播报文后,识别出这是发送端在寻问它IP地址,于是发送一个ARP应答。这个ARP应答包含IP地址及对应的硬件地址。
8)收到ARP应答后,使ARP进行请求——应答交换的IP数据报现在就可以传送了。
9)发送IP数据报到目的主机。
在ARP背后有一个基本概念,那就是网络接口有一个硬件地址(一个48bit的值,标识不同的以太网或令牌环网网络接口)。在硬件层次上进行的数据帧交换必须有正确的接口地址。内核(如以太网驱动程序)必须知道目的端的硬件地址才能发送数据。ARP的功能是在32bit的IP地址和采用不同网络技术的硬件地址之间提供动态映射。点对点链路不适用ARP。
如果ARP请求是从一个网络的主机发往另一个网络上的主机,那么连接这两个网络的路由器就可以回答该请求,这个过程称作委托ARP或ARP代理。这样可以欺骗发起ARP请求的发送端,使他误以为路由器就是目的主机,而事实上目的主机是在路由器的“另一边”。路由器的功能相当于目的主机的代理,把分组从其他主机转发给它。