用途:
当一台主机把以太网数据帧发送给同一局域网上的另一台主机时,是根据48bit的以太网地址来确定目的接口的,设备驱动程序从不检查IP数据报中的目的IP地址。
ARP为IP地址到对应的硬件地址之间提供动态映射,这个过程是自动完成的,不需操心
实例:
当我们执行 ftp someone ,总会经历以下步骤:
1、 应用程序FTP客户端调用函数把主机名(someone)转换成32 bit的IP地址(透过DNS或是较小网络中的/etc/hosts)
2、 FTP客户端请求TCP用得到的IP地址建立连接
3、 TCP发送一个连接请求分段到远端的主机,即用上述IP发送IP数据报
4、 如果目的主机在本地网络(以太网或点对点连接另一端),那么IP数据报可直接发送到该目的主机上; 那么就通过IP选路来确定下一跳,让其转发。 两种情况下,都 是将IP数据报发送至本地网络上的一个主机或是路由器
5、假定是处于一个以太网的,那么发送端必须把32bit的IP地址变换成48bit的以太网地址。
从IP地址到硬件地址需要翻译,这就是ARP协议的功能。
ARP本来是用于广播网络的,有许多主机或路由器连在同一个网络上
6、ARP发送一份称作ARP请求的以太网数据帧给以太网上每个主机,这个过程即为广播。该请求数据帧中包含目的主机的IP地址
7、目的主机的ARP层收到这个广播报文后,识别出这是发送端正是在询问它的硬件地址,于是发送ARP应答。包含IP地址及对应的硬件地址
8、收到ARP应答后,IP数据报就可以开始传送了
9、发送IP数据报
在使用ARP背后的一些概念:
1、网络接口有一个硬件地址
2、知道主机的IP地址并不能让内核发送数据帧给主机,必须知道目的端的硬件地址才能发送
3、点对点链路不使用ARP协议
当一台主机把以太网数据帧发送给同一局域网上的另一台主机时,是根据48bit的以太网地址来确定目的接口的,设备驱动程序从不检查IP数据报中的目的IP地址。
ARP为IP地址到对应的硬件地址之间提供动态映射,这个过程是自动完成的,不需操心
实例:
当我们执行 ftp someone ,总会经历以下步骤:
1、 应用程序FTP客户端调用函数把主机名(someone)转换成32 bit的IP地址(透过DNS或是较小网络中的/etc/hosts)
2、 FTP客户端请求TCP用得到的IP地址建立连接
3、 TCP发送一个连接请求分段到远端的主机,即用上述IP发送IP数据报
4、 如果目的主机在本地网络(以太网或点对点连接另一端),那么IP数据报可直接发送到该目的主机上; 那么就通过IP选路来确定下一跳,让其转发。 两种情况下,都 是将IP数据报发送至本地网络上的一个主机或是路由器
5、假定是处于一个以太网的,那么发送端必须把32bit的IP地址变换成48bit的以太网地址。
从IP地址到硬件地址需要翻译,这就是ARP协议的功能。
ARP本来是用于广播网络的,有许多主机或路由器连在同一个网络上
6、ARP发送一份称作ARP请求的以太网数据帧给以太网上每个主机,这个过程即为广播。该请求数据帧中包含目的主机的IP地址
7、目的主机的ARP层收到这个广播报文后,识别出这是发送端正是在询问它的硬件地址,于是发送ARP应答。包含IP地址及对应的硬件地址
8、收到ARP应答后,IP数据报就可以开始传送了
9、发送IP数据报
在使用ARP背后的一些概念:
1、网络接口有一个硬件地址
2、知道主机的IP地址并不能让内核发送数据帧给主机,必须知道目的端的硬件地址才能发送
3、点对点链路不使用ARP协议
使用命令 arp -a 可查看ARP高速缓存
ARP代理
如果ARP请求是从一个网络的主机发往另一个网络上的主机,那么连接这两个网络的路由器就可以回答该请求,这就是 Proxy ARP,即ARP代理
以下举个例子:
当子网140.252.1上的其他主机(gemini)有一份IP数据报要传给地址为140.252.1.29的sun时,主机gemini比较网络号140.252和子网号1,既然都是相同的,那就在本地局域网发送IP地址为140.252.1.29的ARP请求。
路由器netb识别出这个IP地址属于它的一个拨号主机,于是把它的以太网接口地址140.252.1作为硬件地址来回答。
于是大致过程就是gemini通过以太网发送IP数据给netb,netb通过拨号链路把数据转发给sun。
现在我们来看看gemini的arp高速缓存内容:
我们可以发现他们的硬件地址是相同的,这就表明有是有ARP代理的可能。
ARP代理还有其他用途:
通过两个物理网络之间的路由器可以互相隐藏物理网络。这种情况下,两个物理网络可以使用相同的网络号,只要把中间的路由器设置成一个ARP代理,以响应一个网络到另一个网络的主机ARP请求