ImageVerifierCode 换一换
格式:DOCX , 页数:9 ,大小:245.24KB ,
资源ID:21113313      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/21113313.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(IGMP 详解Word格式.docx)为本站会员(b****6)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

IGMP 详解Word格式.docx

1、图1 3 - 2显示了长度为8字节的IGMP报文格式。IGMP(Internet组管理协议)报文及协议(图二) 这是版本为1的IGMP。 IGMP共有三个版本1、2和3。目前普遍使用的是版本2。 IGMP类型为1说明是由多播路由器发出的查询报文,为2说明是主机发出的报告报文。检验和的计算和ICMP协议相同。组地址为D类IP地址。在查询报文中组地址设置为0,在报告报文中组地址为要参加的组地址。在下一节中,当介绍IGMP如何操作时,我们将会更详细地了解它们。IGMP报文V2版本 (RFC2236 、RFC3376): 类型字段(type):原版本和类型合并,其中值等于0x11为Membership

2、 query;0x12为IGMP v1 Membership report,0x16为IGMP v2 Membership report(join),0x17为IGMP v2 leave. 最大响应时间(Max Resp Time):缺省为10秒,规定在发送回应报告之前的最大延迟时间,1/10秒为单位组地址字段(Group Address):32位D类IP地址。3、 IGMP 协议3.1 加入一个多播组发送上行join包多播的基础就是一个进程的概念(使用的术语进程是指操作系统执行的一个程序),该进程在一个主机的给定接口上加入了一个多播组。在一个给定接口上的多播组中的成员是动态的它随时因进程加入

3、和离开多播组而变化。这里所指的进程必须以某种方式在给定的接口上加入某个多播组。进程也能离开先前加入的多播组。这些是一个支持多播主机中任何API所必需的部分。使用限定词“接口”是因为多播组中的成员是与接口相关联的。一个进程可以在多个接口上加入同一多播组。Stanford大学伯克利版Unix中的IP 多播详细说明了有关socket API的变化,这些变化在Solaris 2.x和ip(7)的文档中也提供了。这里暗示一个主机通过组地址和接口来识别一个多播组。主机必须保留一个表,此表中包含所有至少含有一个进程的多播组以及多播组中的进程数量。 发送加入消息(版本1和版本2都支持的消息)3.2 IGMP

4、报告和查询多播路由器使用IGMP报文来记录与该路由器相连网络中组成员的变化情况。使用规则如下:1) 当第一个进程加入一个组时,主机就发送一个IGMP报告。如果一个主机的多个进程加入同一组,只发送一个IGMP报告。这个报告被发送到进程加入组所在的同一接口上。2) 进程离开一个组时,主机不发送IGMP报告,即便是组中的最后一个进程离开。主机知道在确定的组中已不再有组成员后,在随后收到的IGMP查询中就不再发送报告报文。IGMP v1不发送,IGMP v2发送。3) 多播路由器定时发送IGMP查询来了解是否还有任何主机包含有属于多播组的进程。多播路由器必须向每个接口发送一个IGMP查询。因为路由器希

5、望主机对它加入的每个多播组均发回一个报告,因此IGMP查询报文中的组地址被设置为0.4) 主机通过发送IGMP报告来响应一个IGMP查询,对每个至少还包含一个进程的组均要发回IGMP报告。使用这些查询和报告报文,多播路由器对每个接口保持一个表,表中记录接口上至少还包含一个主机的多播组。当路由器收到要转发的多播数据报时,它只将该数据报转发到(使用相应的多播链路层地址)还拥有属于那个组主机的接口上。图1 3 - 3显示了两个IGMP报文,一个是主机发送的报告,另一个是路由器发送的查询。该路由器正在要求那个接口上的每个主机说明它加入的每个多播组。维护组 路由器查询发往224.0.0.1 一个成员发送

6、回应,其它成员抑制回应查询者选取(版本2中) 最初所有路由器发送查询 最低IP地址路由器被选为查询者,其它路由器成为非查询者离开组(版本1) 主机安静离开组(离开组之前不发送任何信息) 路由器发送3此查询无回应(3分钟左右),则超时。离开组(版本2)发送上行leave包 主机发送离开报告 路由器发送查询无回应,则超时 约3秒钟3.3 实现细节为改善该协议的效率,有许多实现的细节要考虑。首先,当一个主机首次发送IGMP报告(当第一个进程加入一个多播组)时,并不保证该报告被可靠接收(因为使用的是IP交付服务)。下一个报告将在间隔一段时间后发送。这个时间间隔由主机在0 1 0秒的范围内随机选择。其次

7、,当一个主机收到一个从路由器发出的查询后,并不立即响应,而是经过一定的时间间隔后才发出一些响应(采用“响应”的复数形式是因为该主机必须对它参加的每个组均发送一个响应)。既然参加同一多播组的多个主机均能发送一个报告,可将它们的发送间隔设置为随机时延。在一个物理网络中的所有主机将收到同组其他主机发送的所有报告,因为如图1 3 - 3所示的报告中的目的地址是那个组地址。这意味着如果一个主机在等待发送报告的过程中,却收到了发自其他主机的相同报告,则该主机的响应就可以不必发送了。因为多播路由器并不关心有多少主机属于该组,而只关心该组是否还至少拥有一个主机。的确,一个多播路由器甚至不关心哪个主机属于一个多

8、播组。它仅仅想知道在给定的接口上的多播组中是否还至少有一个主机。在没有任何多播路由器的单个物理网络中,仅有的IGMP通信量就是在主机加入一个新的多播组时,支持IP多播的主机所发出的报告。3.4 生存时间字段在图1 3 - 3中,我们注意到IGMP报告和查询的生存时间(TTL,Time To Live)均设置为1,这涉及到IP首部中的TTL字段。一个初始TTL为0的多播数据报将被限制在同一主机。在默认情况下,待传多播数据报的TTL被设置为1,这将使多播数据报仅局限在同一子网内传送。更大的TTL值能被多播路由器转发。回顾6 . 2节,对发往一个多播地址的数据报从不会产生ICMP差错。当TTL值为0

9、时,多播路由器也不产生ICMP“超时”差错。在正常情况下,用户进程不关心传出数据报的TTL.然而,一个例外是Traceroute程序(第8章),它主要依据设置TTL值来完成。既然多播应用必须能够设置要传送数据报的TTL值,这意味着程序设计接口必须为用户进程提供这种能力。通过增加TTL值的方法,一个应用程序可实现对一个特定服务器的扩展环搜索(eXPandingring search)。第一个多播数据报以TTL等于1发送。如果没有响应,就尝试将TTL设置为2,然后3,等等。在这种方式下,该应用能找到以跳数来度量的最近的服务器。从224.0.0.0到224.0.0.255的特殊地址空间是打算用于多播

10、范围不超过1跳的应用。不管TTL值是多少,多播路由器均不转发目的地址为这些地址中的任何一个地址的数据报。3.5 所有主机组在图1 3 - 3中,我们看到了路由器的IGMP查询被送到目的IP地址224.0.0.1(非组地址,group IP=0.0.0.0)该地址被称为所有主机组地址。它涉及在一个物理网络中的所有具备多播能力的主机和路由器。当接口初始化后,所有具备多播能力接口上的主机均自动加入这个多播组。这个组的成员无需发送IGMP报告。4 、一个例子现在我们已经了解了一些IP多播的细节,再来看看所包含的信息。我们使sun主机能够支持多播,并将采用一些多播软件所提供的测试程序来观察具体的过程。首

11、先,采用一个经过修改的netstat命令来报告每个接口上的多播组成员情况(在3.9节显示了netstat-ni命令的输出结果)。在下面的输出中,用黑体表示有关的多播组。IGMP(Internet组管理协议)报文及协议(图四)其中, - n参数将以数字形式显示IP地址(而不是按名字来显示它们),- i参数将显示接口的统计结果,- a参数将显示所有配置的接口。输出结果中的第2行le0(以太网)显示了这个接口属于主机组224.0.0.1(“所有主机”),和两行地址,后一行显示相应的以太网地址为:01: 00:5e:00:01.这正是我们期望看到的以太网地址,和12 . 4节介绍的地址映射一致。我们还

12、看到其他两个支持多播的接口:SLIP接口sl0和回送接口l o 0,它们也属于所有主机组。我们也必须显示IP路由表,用于多播的路由表同正常的路由表一样。黑体表项显示了所有传往224.0.0.0的数据报均被送往以太网:IGMP(Internet组管理协议)报文及协议(图五)如果将这个路由表与9 . 2节中s u n路由器的路由表作比较,会发现只是多了有关多播的条目。现在使用一个测试程序来让我们能在一个接口上加入一个多播组(不再显示使用这个测试程序的过程)。在以太网接口( 1 4 0 . 2 5 2 . 1 3 . 3 3)上加入多播组2 2 4 . 1 . 2 . 3.执行n e t s t a

13、 t程序看到内核已加入这个组,并得到期望的以太网地址。用黑体字来突出显示和前面n e t s t a t输出的不同。IGMP(Internet组管理协议)报文及协议(图六)我们在输出中再次显示了其他两个接口: s l 0和l o 0,目的是为了重申加入多播组只发生在一个接口上。图1 3 - 4显示了t c p d u m p对进程加入这个多播组的跟踪过程。IGMP(Internet组管理协议)报文及协议(图七)当主机加入多播组时产生第1行的输出显示。第2行是经过时延后的IGMP报告,我们介绍过报告重发的时延是1 0秒内的随机时延。在两行中显示硬件地址证实了以太网目的地址就是正确的多播地址。我们

14、也看到了源IP地址为相应的s u n主机地址,而目的IP地址是多播组地址。同时,报告的地址和期望的多播组地址是一致的。最后,我们注意到,正像指明的那样, TTL是1.当TTL的值为0或1时,tcpdump在打印时用方括号将它们括起来,这是因为TTL在正常情况下均高于这些值。然而,使用多播我们期望看到许多TTL为1的IP数据报。在这个输出中暗示了一个多播路由器必须接收在它所有接口上的所有多播数据报。路由器无法确定主机可能加入哪个多播组。5、多播路由器的例子继续前面的例子,但我们将在s u n主机中启动一个多播选路的守护程序。这里我们感兴趣的并不是多播选路协议,而是要研究所交换的IGMP查询和报告

15、。即使多播选路守护程序只运行在支持多播的主机(sun)上,所有的查询和报告都将在那个以太网上进行多播,所以我们在该以太网中的其他系统中也能观察到它们。在启动选路守护程序之前,加入另外一个多播组224.9.9.9,图13-5显示了输出的结果。IGMP(Internet组管理协议)报文及协议(图八)在这个输出中没有包括以太网地址,因为已经证实了它们是正确的。也删去了TTL等于1的说明,同样因为它们也是我们期望的那样。当选路守护程序启动时,输出第1行。它发出一个已经加入了组224.0.0.4的报告。多播地址224.0.0.4是一个知名的地址,它被当前用于多播选路的距离向量多播选路协议DVMRP(Di

16、stance Vector Multicast Routing Protocol)所使用(DVMRP在RFC 1075中定义Waitzman ,Partridge, and Deering)。在该守护程序启动时,它也发送一个IGMP查询(第2行)。该查询的目的IP地址为224.0.0.1(所有主机组),如图13-3所示。第一个报告(第3行)大约在5秒后收到,报告给组224.9.9.9.这是在下一个查询发出之前(第4行)收到的唯一报告。当守护程序启动后,两次查询(第2行和第4行)发出的间隔很短,这是因为守护程序要将其多播路由表尽快建立起来。第5、6和7行正是我们期望看到的:sun主机针对它所属的

17、每个组发出一个报告。注意组224.0.0.4是被报告的,而其他两个组则是明确加入的,因为只要选路守护程序还在运行,它始终要属于组224.0.0.4.下一个查询位于第8行,大约在前一个查询的2分钟后发出。它再次引发三个我们所期望的报告(第9、10和11行)。这些报告的时间顺序与前面不同,因为接收查询和发送报告的时间是随机的。最后的查询在前一个查询的大约2分钟后发出,我们再次得到了期望的响应。多播是一种将报文发往多个接收者的通信方式。在许多应用中,它比广播更好,因为多播降低了不参与通信的主机的负担。简单的主机成员报告协议( IGMP )是多播的基本模块。在一个局域网中或跨越邻近局域网的多播需要使用本章介绍的技术。广播通常局限在单个局域网中,对目前许多使用广播的应用来说,可采用多播来替代广播。然而,多播还未解决的一个问题是在广域网内的多播。Deering and Cheriton 1990 提出扩展目前的路由协议来支持多播。9.13节中的Perlman 1992讨论了广域网多播的一些问题。Casner and Deering 1992 介绍了使用多播和一个称为MBONE(多播主干)的虚拟网络在整个Internet上传送IETF会议的情况。

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1