程序员程序猿阵线联盟-汇总各类技术干货IOS

网络协议补完计划--ARP协议和RARP协议

2018-05-31  本文已影响93人  kirito_song

目录


前言

参照清华大学出版社-罗军周主编的《TCP/IP协议及网络编程技术》进行学习。
本篇主要参考第四章:《ARP和RARP》
介绍如何使用ARP协议通过IP地址映射回来对应的MAC地址、进而进行具体的物理通讯。
对于端内和端外ARP协议的工作有哪些不同。
以及RARP协议的相关知识。


ARP协议和RARP协议概述

上一章所讲的IP地址(192.168.1.1)依旧属于逻辑地址(北京108号信箱)、那么如何将逻辑地址对应到物理网卡MAC地址(玉泉路19号)上?

ARP协议和RARP协议就负责将IP地址映射到MAC地址上。

而在IPV6的环境中已经没有ARP协议了。ICMPV6里的“NS/NA”结合“被请求节点组播地址”代替ARP完成了工作。


以太网的传输机制

以太网是一种广播网络、即在同一个以太网中的任何一个主机都能接收到网络上的所有数据帧。但主机会检查数据帧的目的地址、如果该数据不是发送给自己的、那么就会将其丢弃。
因此、连接到以太网中的每一个连接口(通常是网卡)都会有一个自己唯一的以太网地址(MAC地址)。
如果MAC地址匹配、再交给对应的网络层交给IP协议处理。

IP协议将数据包交给网卡发送的时候、必须告诉网卡将数据发送给那个MAC地址。
IP协议在通讯的时候必须知道对方的MAC地址。
也就是说。IP协议中有一张表、表中记录着每个IP地址对应的MAC地址。这个表产生的过程、就是IP地址向MAC地址的映射过程。


ARP协议

ARP协议(地址解析协议)。
用来查找同一个物理网络中与一个IP地址相关联的MAC地址。

这里参照《图解ARP协议(四)代理ARP原理与实践(“善意的欺骗”)》进行整理

使用询问、回答的机制(源主机H、IP地址P、MAC地址M)。

当两个主机H1、H2处于同一个物理网络:

同网段ARP协议

当两个主机H1、H2处于不同的物理网络:

这时、需要引入两概念、代理ARP网关

网关IP就是默认路由的内网IP地址.
正常环境下、当用户接入网络时、都会通过DHCP协议或手工配置的方式得到IP和网关信息。


网关

当ARP请求目标跨网段时、网关设备收到此ARP请求、会用自己的MAC地址返回给请求者、这便是代理ARP(Proxy ARP)。


代理ARP

需要注意的是网关即便有代理ARP功能,也未必一定执行,还必须满足两个条件:①网关已经开启代理ARP功能;②网关有目标的路由信息。
可能会出现"XXX设备不支持代理ARP功能,导致通信故障"的情况。

①当电脑没有网关(采用代理ARP)时:"跨网段访问谁,就问谁的MAC"

②当电脑有网关(采用正常ARP)时:"跨网段访问谁,都问网关的MAC"

③无论哪种ARP,跨网段通信时,发送方请求得到的目标MAC地址都是网关MAC。

多个路由器下的异网转发

IP不变、MAC变就行了。这是我学CCNA时、听过最经典的总结。

A网关收到数据包后查看,根据目的IP(B的IP地址)查找路由表,找到通往目的网段的路由及下一跳,得到下一跳的MAC地址(ARP获得的),然后将数据包中原IP、目的IP保持不变,原MAC地址换成A网关的MAC地址,目的地址换成下一跳的MAC地址,转发到下一跳的设备(路由器,三层交换机等)。

减少ARP协议的使用次数

如果每次发送一个IP数据包都需要通过ARP协议进行一次ARP请求数据包的广播和ARP响应数据包的发送、那么代价将非常高。
实际上、每个主机可以制作一个《缓存表》来减少这种地址解析所需的通信。
缓存表中有三个字段:IP地址MAC地址以及该记录最后的更新时间(超过一段时间未更新则删除该条数据)。


ARP数据包格式

ARP数据包的格式和RARP数据包的格式相同、只是操作位不同而已。所以、RARP的数据包将不再赘述。

再来看看具体操作流程:

  • 请求者:将数据填好后将《目标硬件地址》空缺、将《操作》写成1发送。
  • 响应者:收到ARP请求后、将请求者信息放入缓存表
  • 响应者:将自身的MAC地址填写进《目标硬件地址》后、将目标位字段与发送位字段互换、将《操作》改写成2发送。
  • 请求者:收到ARP响应后、将响应者信息放入缓存表。

RARP协议

ARP--地址解析协议的反向版。起到给物理地址分配IP地址的作用。

通常是需要远程启动(类似无盘工作站)的系统中使用
RARP协议的工作原理

ARP欺骗

在局域网中,黑客经过收到ARP Request广播包,能够偷听到其它节点的 (IP, MAC) 地址, 黑客就伪装为A,告诉B (受害者) 一个假地址,使得B在发送给A 的数据包都被黑客截取,而B 浑然不知。


参考资料

知乎--电脑是怎么通过ip找到对应的终端的?
图解ARP协议(四)代理ARP原理与实践(“善意的欺骗”)
知乎--路由器中是否有arp缓存表? ?
百度知道--不同网段和同一网段的 ARP 解析

上一篇下一篇

猜你喜欢

热点阅读