004ARP地址解析汇报协议详情.doc
《004ARP地址解析汇报协议详情.doc》由会员分享,可在线阅读,更多相关《004ARP地址解析汇报协议详情.doc(9页珍藏版)》请在课桌文档上搜索。
1、word下载第4章ARP:地址解析协议本章我们要讨论的问题是只对TCP/IP协议簇有意义的IP地址。数据链路如以太网或令牌 环网都有自己的寻址机制常常为48bit地址,这是使用数据链路的任何网络层都必须遵从 的。一个网络如以太网可以同时被不同的网络层使用。例如,一组使用 TCP/IP协议的主机和 另一组使用某种PC网络软件的主机可以共享一样的电缆。当一台主机把以太网数据帧发送到位于同一局域网上的另一台主机时,是根据48bit的以 太网地址来确定目的接口的。设备驱动程序从不检查IP数据报中的目的IP地址。地址解析为这两种不同的地址形式提供映射:32bit的IP标准文档地址和数据链路层使用的任何类
2、型的地址。RFC826Plummer1982是ARP规X描述文档。 本章与下一章我们要讨论的两种协议如图4-1所示:ARP地址解析协议和RARP逆地址解析协议。ARP为IP地址到对应的硬件地址之间提供动态映射。我们 之所以用动态这个词是因为这个过程是自动完成的,一般应用 程序用户或系统管理员不必关心。32位Internet地址48位以太网地址图4-1 地址解析协议:ARP和RARPRARP是被那些没有磁盘驱动器的系统使用一般是无盘工作站或X终端,它需要系统 管理员进展手工设置。我们在第5章对它进展讨论。任何时候我们敲入下面这个形式的命令:%ftpbsdi都会进展以下这些步骤。这些步骤的序号如图
3、4-2所示。1)应用程序FTP客户端调用函数gethostbyname(3)把主机名bsdi转换成32 bit的IP地址。 这个函数在DNS域名系统中称作解析器,我们将在第14章对它进展介绍。这个转换 过程或者使用DNS,或者在较小网络中使用一个静态的主机文件/etc/hosts。2)FTP客户端请求TCP用得到的IP地址建立连接。3) TCP发送一个连接请求分段到远端的主机,即用上述IP地址发送一份IP数据报在第18章我们将讨论完成这个过程的细节。4)如果目的主机在本地网络上如以太网、令牌环网或点对点的另一端,那么IP数 据报可以直接送到目的主机上。如果目的主机在一个远程网络上,那么就通过
4、IP选路 函数来确定位于本地网络上的下一站路由器地址,并让它转发 IP数据报。在这两种情 况下,IP数据报都是被送到位于本地网络上的一台主机或路由器。5)假定是一个以太网,那么发送端主机必须把32bit的IP地址变换成48bit的以太网地址。从逻辑Internet地址到对应的物理硬件地址需要进展翻译。这就是ARP的功能。ARP本来是用于广播网络的,有许多主机或路由器连在同一个网络上。6)ARP发送一份称作ARP请求的以太网数据帧给以太网上的每个主机。这个过程称作广 播,如图4-2中的虚线所示。ARP请求数据帧中包含目的主机的IP地址主机名为 bsdi,其意思是“如果你是这个IP地址的拥有者,请
5、回答你的硬件地址。主机名解析器主机名IP地址用IP地址建立连接给IP地址发送IP数据报ARP请求(以太网广播)以太网 驱动程序以太网驱动程序以太网 驱动程序图4-2 当用户输入命令“ftp 主机名时ARP的操作7)目的主机的ARP层收到这份广播报文后,识别出这是发送端在寻问它的IP地址,于是 发送一个ARP应答。这个ARP应答包含IP地址与对应的硬件地址。8)收到ARP应答后,使ARP进展请求应答交换的IP数据报现在就可以传送了。9)发送IP数据报到目的主机。 在ARP背后有一个根本概念,那就是网络接口有一个硬件地址一个48bit的值,标识不同的以太网或令牌环网络接口。在硬件层次上进展的数据帧
6、交换必须有正确的接口地址。但 是,TCP/IP有自己的地址:32bit的IP地址。知道主机的IP地址并不能让内核发送一帧数据给 主机。内核如以太网驱动程序必须知道目的端的硬件地址才能发送数据。 ARP的功能是 在32 bit的IP地址和采用不同网络技术的硬件地址之间提供动态映射。点对点链路不使用ARP。当设置这些链路时一般在引导过程进展,必须告知内核链路每一端的IP地址。像以太网地址这样的硬件地址并不涉与。4.3 ARP高速缓存ARP高效运行的关键是由于每个主机上都有一个 ARP高速缓存。这个高速缓存存放了最 近Internet地址到硬件地址之间的映射记录。高速缓存中每一项的生存时间一般为 2
7、0分钟,起 始时间从被创建时开始算起。我们可以用arp(8)命令来检查ARP高速缓存。参数-a的意思是显示高速缓存中所有的内容。bsdi%arp-asun)at8:0:20:3:f6:42 svr4)at0:0:c0:c2:9b:2648bit的以太网地址用6个十六进制的数来表示,中间以冒号隔开。在4.8小节我们将讨论arp命令的其他功能。4.4 ARP的分组格式在以太网上解析IP地址时,ARP请求和应答分组的格式如图4-3所示ARP可以用于其他 类型的网络,可以解析IP地址以外的地址。紧跟着帧类型字段的前四个字段指定了最后四个 字段的类型和长度。以太网 目的地址以太网 源地址帧 硬件协议 类
8、型类型类型硬件地址长度 协议地址长度发送端 以太网地址发送端IP地址目的以太网目的 地址IP地址以太网首部28字节ARP请求/应答图4-3 用于以太网的ARP请求或应答分组格式以太网报头中的前两个字段是以太网的源地址和目的地址。目的地址为全1的特殊地址是 广播地址。电缆上的所有以太网接口都要接收广播的数据帧。两个字节长的以太网帧类型表示后面数据的类型。对于ARP请求或应答来说,该字段的 值为0x0806。形容词hardware(硬件)和protocol(协议)用来描述ARP分组中的各个字段。例如,一个ARP请求分组询问协议地址这里是IP地址对应的硬件地址这里是以太网地址。 硬件类型字段表示硬件
9、地址的类型。它的值为1即表示以太网地址。协议类型字段表示要映射的协议地址类型。它的值为0x0800即表示IP地址。它的值与包含IP数据报的以太网数据 帧中的类型字段的值一样,这是有意设计的参见图2-1。接下来的两个1字节的字段,硬件地址长度和协议地址长度分别指出硬件地址和协议地址 的长度,以字节为单位。对于以太网上IP地址的ARP请求或应答来说,它们的值分别为6和4。 操作字段指出四种操作类型,它们是ARP请求值为1、ARP应答值为2、RARP请求值为3和RARP应答值为4我们在第5章讨论RARP。这个字段必需的,因为ARP请求 和ARP应答的帧类型字段值是一样的。接下来的四个字段是发送端的硬
10、件地址在本例中是以太网地址、发送端的协议地址IP地址、目的端的硬件地址和目的端的协议地址。注意,这里有一些重复信息:在以太网的数据帧报头中和ARP请求数据帧中都有发送端的硬件地址。对于一个ARP请求来说,除目的端硬件地址外的所有其他的字段都有填充值。当系统收 到一份目的端为本机的ARP请求报文后,它就把硬件地址填进去,然后用两个目的端地址分 别替换两个发送端地址,并把操作字段置为2,最后把它发送回去。4.5 ARP举例在本小节中,我们用tcpdump命令来看一看运行像Telnet这样的普通TCP工具软件时ARP会做些什么。附录A包含tcpdump命令的其他细节。4.5.1 一般的例子为了看清楚
11、ARP的运作过程,我们执行telnet命令与无效的服务器连接。检验ARP高速缓存是空的 连接无效的服务器键入Ctrl和右括号,使Telnet回到提示符并关闭当我们在另一个系统sun上运行带有-e选项的tcpdump命令时,显示的是硬件地址在我们的例子中是48 bit的以太网地址。图4-4中的tcpdump的原始输出如附录A中的图A-3所示。由于这是本书第一个tcpdump输出例子,你应该去查看附录中的原始输出,看看我们作了哪些修改。图4-4 TCP连接请求产生的ARP请求和应答我们删除了tcpdump命令输出的最后四行,因为它们是完毕连接的信息我们将在第18章进展讨论,与这里讨论的内容不相关。
12、在第1行中,源端主机bsdi的硬件地址是0:0:c0:6f:2d:40。目的端主机的硬件地址是 ff:ff:ff:ff:ff:ff,这是一个以太网广播地址。电缆上的每个以太网接口都要接收这个数据帧并对 它进展处理,如图4-2所示。第1行中紧接着的一个输出字段是arp,明确帧类型字段的值是0x0806,说明此数据帧是 一个ARP请求或回答。在每行中,单词arp或ip后面的值60指的是以太网数据帧的长度。由于ARP请求或回答的数据帧长都是42字节28字节的ARP数据,14字节的以太网帧头,因此,每一帧都必须加 入填充字符以达到以太网的最小长度要求:60字节。请参见图1-7,这个最小长度60字节包含
13、14字节的以太网帧头,但是不包括4个字节的以 太网帧尾。有一些书把最小长度定为64字节,它包括以太网的帧尾。我们在图1-7中把最小长 度定为46字节,是有意不包括14字节的帧首部,因为对应的最大长度1500字节指的是 MTU最大传输单元见图2-5。我们使用MTU经常是因为它对IP数据报的长度进展限制, 但一般与最小长度无关。大多数的设备驱动程序或接口卡自动地用填充字符把以太网数据帧 充满到最小长度。第3,4和5行中的IP数据报包含TCP段的长度都比最小长度短,因此都 必须填充到60字节。第1行中的下一个输出字段arpwho-has表示作为ARP请求的这个数据帧中,目的IP地 址是svr4的地址
14、,发送端的IP地址是bsdi的地址。tcpdump打印出主机名对应的默认IP地址在节中,我们将用-n选项来查看ARP请求中真正的IP地址。从第2行中可以看到,尽管ARP请求是广播的,但是ARP应答的目的地址却是bsdi0:0:c0:6f:2d:40。ARP应答是直接送到请求端主机的,而是广播的。 tcpdump打印出arprepl的y字样,同时打印出响应者的主机名和硬件地址。 第3行是第一个请求建立连接的TCP段。它的目的硬件地址是目的主机(svr4)。我们将在第18章讨论这个段的细节内容。在每一行中,行号后面的数字表示tcpdump收到分组的时间以秒为单位。除第1行外, 其他每行在括号中还包
15、含了与上一行的时间差异以秒为单位。从这个图可以看出,发送 ARP请求与收到ARP回答之间的延时是2.2ms。而在0.7ms之后发出第一段TCP报文。在本例 中,用ARP进展动态地址解析的时间小于3 ms。最后需要指出的一点,在tcpdump命令输出中,我们没有看到svr4在发出第一段TCP报 文第4行之前发出的ARP请求。这是因为可能在svr4的ARP高速缓存中已经有bsdi的表 项。一般情况下,当系统收到ARP请求或发送ARP应答时,都要把请求端的硬件地址和IP地 址存入ARP高速缓存。在逻辑上可以假设,如果请求端要发送IP数据报,那么数据报的接收 端将很可能会发送一个应答。4.5.2 对不
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 004 ARP 地址 解析 汇报 协议 详情

链接地址:https://www.desk33.com/p-9236.html