tcp/ip ---------- ARP协议

本文详细解释了ARP协议如何实现IP地址到硬件地址的动态映射,包括DNS解析、TCP连接建立、IP数据报发送以及ARP请求与应答的过程。还介绍了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请求


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值