今天上课讲到ARP协议,但是对一些APR表项的更新有一些疑问,所以查询了有关资料。
依据ARP协议描述,几乎所有的以太网通信都以ARP开始,所以任何以太网主机设备都支持这个协议,而且IP地址到以太网MAC地址的解析主要也是动态生成,无须网络管理员手工处理。
一般实现中,如果收到的ARP报文满足以下条件中的任何一条,系统将创建或更新ARP表项:
ARP报文的源IP地址与入接口IP地址在同一网段,且不是广播地址,目的IP地址是本接口IP地址。ARP报文的源IP地址与入接口IP地址在同一网段,且不是广播地址,目的IP地址是本接口的VRRP(Virtual Router Redundancy Protocol)虚拟IP地址。
如果收到的ARP报文的源IP地址在入接口的ARP表中已经存在对应表项,也将对ARP表项进行更新。
文章出自ARP
有这么广泛流传的一段话,如果ARP报文的目的IP地址与本机的相同,则将报文中的IP地址和MAC地址添加到ARP缓存表项中,假如已经存在该IP的表项,则进行更新;然后,回复一个应答包。如果IP地址和本机的IP地址不符合,则丢弃报文。
那么问题来了,在IP地址和本机IP地址不符合的情况下,是否要进行ARP缓存表项的更新?
如果不进行更新,那么免费ARP(也是ARP请求,op字段为1)又怎么会实现他的作用呢,这里我们将免费ARP简单介绍一下。
免费ARP是一个目的IP地址是本机IP地址的ARP。发送一个免费ARP,我们可以判断局域网内是否有重复IP地址的主机(显然我们不希望有),我们也可以在更新mac地址(例如换网卡)后发送免费ARP来更新其他主机的ARP缓存表项,当其他电脑收到这个arp 广播时会和ARP缓存做对比,并更新ARP缓存,如果ARP缓存中没有这个IP的记录则直接忽视这个广播包。
现在我们可以假设,当ARP请求包的目的IP地址与本机IP地址不同时,本机会在ARP缓存表项中查找是否有该IP地址,如果有,则更新,如果没有,则不做动作,最后本机都会丢弃该数据包。
按照图中的步骤可以解释以上谈到的情况,如有错误,还请指出。
还有一种情况是:
当主机接收到ARP应答数据包的时候,就会对本地的ARP缓存进行更新,将应答中的IP和MAC地址存储在ARP缓存中。
总结:只要主机中有发送端IP的ARP表项,收到它的ARP数据包时就会对ARP表项进行更新。
附上一篇免费ARP的文章 免费ARP简析