IGMP(Internet Group Management Protocol)作为因特网组管理协议,用于多播。

    与ICMP一样, IGMP也被当作 IP 层的一部分,IGMP报文也通过IP数据报进行传输。
         
          
    IGMP 在TCP/IP中负责局域网IP多播组成员管理的协议。用来在多播路由器与其局域网中的主机建立、维护多播组成员关系(组播路由器之间的组成员信息建立、维护使用组播路由协议)。关于多播,请参考《TCP/IP详解、卷一》第十二章。
如图 R1 R2 R3路由所在局域网中均有主机加入多播组。假设网络中有该组一多播数据包传送,那么如何使得该多播数据包只发给R1、R2、R3,而不发给R4.这时,就需要IGMP协议了。

    
        简单的说,IGMP实现了这样的功能,对于主机来说,它通知多播路由器,我在哪些多播组中。对多播路由器而言,IGMP使得多播路由器维护局域网中的主机都加入了哪些组。  
  

基本过程:

    主机:        保存自己加入的组播播组列表
    多播路由器:  保存每个接口连接的网段上是否存在某个组播组的组成员
       1)加入一个组:主机加入一个组,向多播路由器发送IGMP报文,声明成为某个多播组成员。本地多播路由器获取该报文后,就可以将这种成员关系发给其他多播路由器。
        2)动态维护多播组成员关系:多播路由器定时向本地主机发送查询报文,以判断某个多播组在本地主机中是否还有成员。
         
    在动态维护多播组成员关系时,多播路由器发送query报文,如果某个组在本地有多名成员,那么在第一个成员主机respond之后,其他成员主机不必再应答。

        ( 1 ) 在主机和多播路由器之间的所有通信都是使用 IP 多播。只要有可能,携 带 IGMP报文的数据报都用硬件多播来传送。因此在支持硬件多播的网络上,没
有 参 加 I P 多播的主机不会收到 IG M P 报文。
        ( 2 ) 多播路由器在探询组成员关系时,只需要对所有的组发送一个请求信息的询问报文,而不需要对每一个组发送一个询问报文
( 虽然也允许对一个特定组发送询问报文)。默认的询问速率是每 125 秒 发 送 一 次 ( 通信量并不太大)。
        (
3 ) 当同一个网络上连接有几个多播路由器时,它们能够迅速和有效地选择其中的一个来探询主机的成员关系。因此,网络上多个多播路由器并不会引起IGMP通信量的增大。
        ( 4 ) 在 IGMP 的query报文中有最长响应时间
N( 默 认 值 为 10秒 )。当收到query时,主机在0 到N之间随机选择发送响应所需经过的时延。因此,若一个主机同时参加了几个多播组,则主机对每一个多播组选择不同的随机数。对应于最小时延的响应最先发送。
        ( 5 ) 同一个组内的每一个主机都要监听响应,只要有本组的其他主机先发送了响应,自己就可以不再发送响应了。这样就抑制了不必要的通信量。


IGMP目前有三个版本:IGMPv1、IGMPv2、IGMPv3

IGMPv1、IGMPv2、IGMPv3三者的对比:

  IGMPv1 IGMPv2   IGMPv3   
实现机制 基于查询与响应    
查询器 通过多播路由选择协议选举产生 自己有选举机制 自己有选举机制
组员加入     主机主动向要加入的多播组发送加入报告    
组员离开     不立即发送离开报文,只是在下次查询时不响应(即不发送响应报告) 主动发离开报文,查询器收到报文就开始进行特定组查询 主动发离开报文,查询器收到报文就开始进行特定组查询   
指定源、组查询 指定组 指定源、组
指定源、组加入
RFC RFC 1112 RFC 2236  RFC 3376 
       


IGMPv3 的指定组功能:

1、主机控制能力的增强
        IGMPv3 增加了针对组播源的过滤模式(INCLUDE/EXCLUDE),使主机在加入某组播组G的同时,能够明确要求接收或拒绝来自某特定组播源S的组播信息。
    主机加入组播组时:
1)    若要求只接收来自指定组播源如S1、S2、……的组播信息,则其报告报文中可以标记为INCLUDE Sources(S1,S2,……);
2)    若拒绝接收来自指定组播源如S1、S2、……的组播信息,则其报告报文中可以标记为EXCLUDE Sources(S1,S2,……)。



2、查询和报告报文功能的增强
1)携带源地址的查询报文
    IGMPv3 不仅支持IGMPv1 的普遍组查询和IGMPv2 的特定组查询,而且还增加了对特定源组查询的支持:
§  普遍组查询报文中,既不携带组地址,也不携带源地址;
§  特定组查询报文中,携带组地址,但不携带源地址;
§ 特定源组查询报文中,既携带组地址,还携带一个或多个源地址。
2)包含多组记录的报告报文
    IGMPv3 报告报文的目的地址为224.0.0.22,可以携带一个或多个组记录。在每个组记录中,包含有组播组地址和组播源地址列表。其组记录类型分别为: IS_IN,IS_EX,TO_IN,TO_EX,ALLOW,BLOCK六种。
§ IS_IN:表示组播组与组播源列表之间的过滤模式为INCLUDE,即只接收从指定组播源列表发往该组播组的组播数据。
§ IS_EX:表示组播组与组播源列表之间的过滤模式为EXCLUDE,即只接收从指定组播源列表之外的组播源发往该组播组的组播数据。
§ TO_IN:表示组播组与组播源列表之间的过滤模式由EXCLUDE 转变为INCLUDE。
§ TO_EX:表示组播组与组播源列表之间的过滤模式由INCLUDE 转变为EXCLUDE






IGMP 因特网组管理协议的更多相关文章

  1. IGMP Internet组管理协议 未完

    一.IGMP Internet组管理协议 2.IGMP v2 3.IGMP三版本比较 4.1.1.4 IGMP v2 与 IGMP v1 的兼容 5.IGMP窃听(IGMP Snooping) IGM ...

  2. TCP/IP IGMP:Internet组管理协议

    1.概述 IGMP协议,让一个物理网络上的所有系统知道主机所在的多播组,ICMP作为IP层的一部分,通过IP数据报进行传输,有固定的报文长度.通过IP首部协议字段值为2指明 类型为1说明是多播路由器发 ...

  3. TCP/IP详解学习笔记(9)-- 广播,多播,IGMP:网际组管理协议

    1.概述      IP有三种地址:单播地址, 广播地址,多播地址.      广播和多播仅应用于UDP.      每个以太网帧包含源主机和目的主机的以太网地址.通常每个以太网帧发往单个目的主机,目 ...

  4. 广播,多播,IGMP:网际组管理协议

    广播,多播,IGMP:网际组管理协议 1.概述      IP有三种地址:单播地址, 广播地址,多播地址.      广播和多播仅应用于UDP.      每个以太网帧包含源主机和目的主机的以太网地址 ...

  5. TCP/IP详解 卷一(第十三章 IGMP:Internet组管理协议)

    本章将介绍用于支持主机和路由器进行多播的Internet组管理协议(IGMP) 它让一个物理网络上的所有系统知道主机当前所在的多播组.多播路由器需要这些信息以便知道多播数据报应该向那些接口转发. 跟I ...

  6. HCNP Routing&Switching之组播技术-组播协议IGMP

    前文我们了解了组播地址相关话题,回顾请参考https://www.cnblogs.com/qiuhom-1874/p/15616740.html:今天我们来聊一聊组播协议中IGMP协议相关话题: 组播 ...

  7. 计算机网络之网络层IP组播(IGMP、组播路由选择协议、组播地址)

    文章转自:https://blog.csdn.net/weixin_43914604/article/details/105318560 学习课程:<2019王道考研计算机网络> 学习目的 ...

  8. Day03_破解Windows7系统密码&用户与组管理&服务器远程管理

    破解Windows系统密码 一.利用5次shift漏洞破解win7密码 1.1 漏洞 1.在未登录系统时,连续按5次shift键,弹出程序c:\windows\system32\sethc.exe 2 ...

  9. linux-图形化远程管理协议

    远程管理控制方式: RDP(remote desktop protocol)协议: telnet: SSH(Secure Shell): RFB(Remote FrameBuffer)协议(图形化远程 ...

随机推荐

  1. Lucene.Net 3.0.3如何从TokenStream中获取token对象

    Lucene.Net最高版本为3.0.3,并且apache已经不再提供Lucene.Net的更新,没仔细研究过Lucene.Net的所有版本,Lucene.Net3.0.3遍历TokenStream获 ...

  2. Python面试题之Python迭代器

    要理解迭代器,首先要从字面意思来说. 迭代 重复 下一次重复基于上一次的结果 软件开发就是典型的迭代更新. 讲迭代,我们就先来模拟一下迭代: 现在让我们使用while循环来遍历出一个列表list1 = ...

  3. 20145322《Java程序设计》第十周学习总结

    20145322<Java程序设计>第十周学习总结 教材学习内容总结 网络概述 网络编程就是在两个或两个以上的设备(例如计算机)之间传输数据.程序员所作的事情就是把数据发送到指定的位置,或 ...

  4. Oh My Zsh 插件篇 - 实用工具

    Oh My Zsh 除了为我们提供快捷的命令行操作之外,还提供了强大丰富的插件机制,每个社区贡献者都可以贡献自己的插件,让整个生态体系更加丰富完善.今天给大家介绍了一下它的实用工具类插件. 前面我们分 ...

  5. Zookeeper之基于Observer部署架构

    Observers:在不伤害写性能的情况下扩展Zookeeper 虽然通过Client直接连接到Zookeeper集群的性能已经很好了,可是这样的架构假设要承受超大规模的Client,就必须添加Zoo ...

  6. [CF960F]Pathwalks

    题目大意:给你一张$n$个点$m$条边的带权有向图,可能有重边和自环.边会按照顺序给出.让你求出一条最长的路径,使得路径上的边满足边权和出现的时间严格递增.路径可以重复经过同一个点. 想办法把它转化成 ...

  7. PHP 根据IP地址获取所在城市

    header('Content-Type:text/html;Charset=utf-8'); function GetIp(){ $realip = ''; $unknown = 'unknown' ...

  8. 同时打印多个worksheets

    https://support.office.com/en-us/article/print-a-sheet-or-workbook-0f104967-ebce-406f-9c37-d3ab0dc02 ...

  9. kylin入门到实战:入门

    版权申明:转载请注明出处.文章来源:http://bigdataer.net/?p=292 排版乱?请移步原文获得更好的阅读体验 1.概述 kylin是一款开源的分布式数据分析工具,基于hadoop之 ...

  10. 04_zookeeper客户端使用及常用命令

    zookeeper客户端的使用 (1)   首先找到zookeeper自带客户端的位置 简单来说,zookeeper自带客户端位于zookeeper安装目录的bin目录下,以我的为例: (2)   运 ...