IP多播技术详解

news2024/11/28 19:03:10

在这里插入图片描述

文章目录

  • 前言
  • IP多播技术的相关基本概念
    • IP多播地址和多播组
  • 在局域网上进行硬件多播
    • IP多播地址和多播MAC地址映射关系
  • 在因特网上进行IP多播
    • 网际组管理协议IGMP
    • 多播路由选择协议

前言

随着计算机网络的发展和个人计算机的普及,人们能够方便的在网络上畅游,进行网络通信或者获取自己所需的信息资源。此外,人们也越来越依赖于网络计算。大多数企业都建立了先进的网络,连接各个雇员和他们的计算机、工作站。有时,我们工作中的重要的信息只能通过网络得到,这些信息可能在企业的专用网络上,也可能在因特网上。

IP多播技术的相关基本概念

多播(Multicast,也称为组播)是一种实现一对多通信的技术,与传统单播一对一通信相比,多播可以极大地节省网络资源

在因特网上进行的多播,称为IP多播

多播的基础概念是。一个多播组(multicast group)就是一组希望接收特定数据流的接收者。这个组没有物理或者地理的边界:组内的主机可以位于互联网或者专用网络的任何地方。多播组中的每1个节点被称为多播组成员。

举例
在这里插入图片描述

  • 采用单播方式:共有60个主机要接收来自视频服务器的同一个视频节目,则视频服务器需要发送60个该视频节目,这些视频节目通过各路由器的转发,最终到达各主机。
  • 采用多播方式:可将这60个主机看做是同一个多播组的成员,视频服务器只要向该多播组发送1个视频节目即可;由于路由器R1支持IP多播,R1在转发视频节目时需要将该视频节目复制成两个副本,分别向路由器R2、R3转发一个副本,当该视频节目到达目的局域网时,由于局域网具有硬件多播功能,因此不需要复制,在局域网上的该多播组成员都能收到该视频。

当多播组的成员数量很大时,采用多播方式可以显著地减少网络中各种资源的消耗

IP多播地址和多播组

在IPV4中,D类地址被作为多播地址,多播地址只能用作目的地址,而不能用作源地址。

224.0.0.1 所有主机的地址
224.0.0.2 所有组播路由器的地址

在这里插入图片描述
用每一个D类地址来标识一个多播组,使用同一个IP多播地址接收IP多播数据报的所有主机就构成了一个多播组

  • 每个多播组的成员时可以随时变动的,一台主机可以随时加入或离开多播组
  • 多播组成员的数量和所在的地理位置也不受显示,一台主机可以属于几个多播组

非多播组成员也可以向多播组发送IP多播数据报

IPV4多播地址又可以分为:预留的多播地址(永久多播地址)、全球范围可用的多播地址以及本地管理的多播地址
在这里插入图片描述
IP多播可以分为两种:

  1. 只在本局域网上进行的硬件多播
  2. 在因特网上进行的多播

在局域网上进行硬件多播

由于MAC地址(也称硬件地址)有多播MAC地址这种类型,因此只要把IPV4多播地址映射成多播MAC地址,即可将IP多播数据报封装在局域网的MAC帧中,而MAC帧首部的目的MAC地址字段的值,就设置为由IPV4多播地址映射成的多播MAC地址。这样,可以很方便地利用硬件多播来实现局域网内的IP多播。
在这里插入图片描述
当给某个多播组的成员配置其所属组的IP多播地址时,系统就会根据映射规则从该IP多播地址生成相应的局域网多播MAC地址。

因特网号码指派管理局IANA,将自己从IEEE注册管理机构申请到的以太网MAC地址块中从01-00-5E-00-00-00到01-00-5E-7F-FF-FF的多播MAC地址,用于映射IPV4多播地址。

  • 这些多播MAC地址做起前25比特都是相同的,剩余23比特可以任意变化,因此共有2的23次方个(左边第1个字节的最低为比特取值为1,表示该MAC地址是多播MAC地址)
    在这里插入图片描述

IP多播地址和多播MAC地址映射关系

为了映射一个IP多播地址到MAC层的多播地址,IP多播地址的底23位可以直接映射为MAC层多播地址的底23位。因为IP多播地址的前4位是固定的,另外还有比邻的5位不需要映射到MAC层多播地址
在这里插入图片描述
举例
只需将多播MAC地址坐起前25比特固定不变,将IP多播地址的低23比特映射到或者说作为MAC多播地址的低23位,这样就可以得出IP多播地址相应的多播MAC地址
在这里插入图片描述

如果不同的IP多播地址之间的不同指出仅出现在不能映射的那5个比特,则这些IP多播地址会映射出同一个多播MAC地址,因此收到IP多播数据报的主机还要在网际层利用软件进行过滤,把不是主机要接收的IP多播数据报丢弃。

在这里插入图片描述


在因特网上进行IP多播

要在因特网上进行IP多播,就必须要考虑数据报经过多个多播路由器进行转发的问题

  • 多播路由器必须根据IP多播数据报首部中的IP多播地址,将其转发到该多播组成员的局域网

在这里插入图片描述
在因特网上进行IP多播需要两种协议

  • 网际组管理协议IGMP
  • 多播路由选择协议

路由器如何知道各接口所在的局域网是否有某个多播组的成员?
需要使用TCP/IP体系结构网际层中的网际组管理协议IGMP

网际组管理协议IGMP

网际组管理协议(IGMP)是TCP/IP体系结构网际层中的协议,其作用是让连接在本地局域网上的多播路由器知道本地局域网上是否有主机(实际上是主机中的某个进程)加入或退出了某个多播组

IGMP只在本网络有效,使用IGMP并不能知道多播组所包含的成员数量,也不能知道多播组的成员都分布在哪些网络中

仅使用IGMP并不能在因特网上进行IP多播。连接在局域网上的多播路由器还必须和因特网上的其它多播路由器协同工作,以便把IP多播数据报用最小的代价传送给所有的多播组成员,这就需要使用多播路由选择协议

IGMP有三种报文类型

  • 成员报告报文
  • 成员查询报文
  • 离开组报文

IGMP报文被封装在IP数据报中传送

在这里插入图片描述
网际组管理协议IGMP的基本工作原理

  • 加入多播组的情况
    在这里插入图片描述
  • 监视多播组成员变化的情况

    最后返回各个主机或路由器,进行解析
  • 退出多播组情况
    当主机要退出某个多播组时,可主动发送一个离开组报文而不必等待多播路由器的查询。这样可使多播路由器能够更快地发现某个组有成员离开
    在这里插入图片描述
    之后多播路由器发送IGMP成员查询报文

多播路由选择协议

多播路由选择协议的主要任务是:在多播路由器之间为每个多播组建立一个多播转发树

  • 多播转发树连接多播源和所有拥有该多播组成员的路由器
  • IP多播数据报只要沿着多播转发树进行洪泛,就能被传送所有拥有该多播组成员的多播路由器
  • 之后,在多播路由器所直连的局域网内,多播路由器通过硬件多播,将IP多播数据报发送给该多播组的所有成员

在这里插入图片描述

即使某个主机不是任何多播组的成员,它也可以向任何多播组发送多播数据报

目前有两种方式来构建多播转发树:

  1. 基于源树(Source-Bass Tree)多播路由选择
  2. 组共享树(Group-Shared Tree)多播路由选择

基于源树的多播路由选择选择最典型算法是反向路径多播(RPM)算法

RPM算法包含以下两个步骤

  1. 利用反向路径广播算法建立一个广播转发树
  2. 利用剪枝算法,剪除广播转发树中的下游非成员路由器,获得一个多播转发树

建立广播转发树,可以使用洪泛法

利用反向路径广播RPB算法生成的广播转发树,不会存在环路,因此可以避免广播分组在环路中兜圈
在这里插入图片描述


组共享树多播路由选择采用基于核心的分布式生成树算法来建立共享树
该方法在每个多播组中指定一个核心(core)路由器,以该路由器为根,建立一棵连接多播组的所有成员路由器的生成树,作为多播转发树
在这里插入图片描述


本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/345030.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【大数据】YARN节点标签Node Label特性

简介 YARN 的 Node-label 特性能够将不同的机器类型进行分组调度,也可以根据不同的资源要求进行分区调度。运维人员可以根据节点的特性将其分为不同的分区来满足业务多维度的使用需求。YARN的Node-label功能将很好的试用于异构集群中,可以更好地管理和调…

使用 RGB 值设置颜色

使用 RGB 值设置颜色 另一种可以在 CSS 中表示颜色的方法是使用 RGB 值。 RGB 即红色、绿色、蓝色(英语:Red, Green, Blue)。 ● 红色(R)0 到 255 间的整数,代表颜色中的红色成分。。 ● 绿色(G…

【数据结构】基础:图的最小生成树(附C++源代码)

【数据结构】基础:图的最小生成树(附C源代码) 摘要:将会在数据结构专题中开展关于图论的内容介绍,其中包括四部分,分别为图的概念与实现、图的遍历、图的最小生成树以及图的最短路径问题。本文主要介绍Krus…

机器学习经典算法总结

一,KNN 算法 K 近邻算法(KNN)是一种基本分类和回归方法。KNN 算法的核心思想是如果一个样本在特征空间中的 k 个最相邻的样本中的大多数属于一个类别,那该样本也属于这个类别,并具有这个类别上样本的特性。该方法在确…

知识图谱表示

知识图谱表示 用某种语言对知识图谱进行建模,从而方便知识运算。 符号知识表示 :以符号逻辑为基础的知识表示方法。 特点:易于刻画显示、离散的知识。具有内生的可解释性。 不足:部分隐性知识不易符号化表示,故知识表…

Pr LOGO片头动画

哈喽,各位小伙伴!今天我们来学习一下如何制作简约文字LOGO片头动画? 新建序列 新建一个1920*1080的序列,在字幕上打上我们的文字(例:Ultraman) 调出基本面板,调整文字的位置&…

全栈项目【尚医通】预约挂号系统项目介绍

🐼个人主页:爪哇斗罗 🐼博主介绍:一名打工人 🐼签名:圣人之道,为而不争。 🐼一起交流,一起进步,一起互动。 ​ 目录 一.项目介绍 二.技术架构 2.1 架构选…

SpringBoot集成Swagger3(powernode document)(内含源代码)

SpringBoot集成Swagger3(powernode document)(内含源代码) 源代码下载链接地址:https://download.csdn.net/download/weixin_46411355/87449720 目录SpringBoot集成Swagger3(powernode document&#xff0…

数据库锁的12连问,你顶得了嘛?

前言 金三银四很快就要来啦,准备了数据库锁的12连问,相信大家看完肯定会有帮助的。 1. 为什么需要加锁 在日常生活中,如果你心情不好想静静,不想被比别人打扰,你就可以把自己关进房间里,并且反锁。这就是…

Simulink自动代码生成:如何标准化的建模?以MAB,MISRA C 2012建模规范为例

目录 为什么要规范建模 MAB,MISRA C2012建模规范步骤 常用的规范总结 生成代码配置 总结 为什么要规范建模 MathWorks 咨询委员会 (MAB) 规范规定了在 Simulink 和 Stateflow 中建模的重要基本规则。这些建模规范的总体目的是让控制系统模型的建模者和使用方能…

自定义ESLint规则和修复功能

这是接上一篇自定义ESLint规则开发与使用的后续扩展,之前文章中详细讲述了怎么创建一个自定义的规则,这篇文章讲述怎么实现ESLint在检测出有问题的代码时,怎么自动fix问题。 比如我们要检测项目中所有http的协议,将其替换为https协…

Power BI 存储模式介绍(导入、DirectQuery、双)

本系列的文章: 《Power BI windows下载安装流程)》《Power BI 11个必学官方示例数据案例(附下载链接)》《Power BI 数据导入(SQL Server、MySQL、网页数据)》 一、背景原因 一般情况下,我们是…

测试开发面试基础题

1.对测试开发的理解 测试开发首先离不开测试,而软件测试是指,在规定的条件下对程序进行操作,以发现程序错误,衡量软件质量,并对其是否能满足设计要求进行评估的过程。 而且,现在不仅仅是通过手工测试来发…

安装less-loader5出现webpack版本不兼容

今天遇到一个问题: 安装less-loader5之后其它包提示peerDependencies WARNING,意思是包版本不兼容。 【难题】 虽然NPM已经很自动化了,但依赖问题真的是一个难题,无法自动解决,需要人工干预调整。 【解决办法】 去查…

用户选择好用的投票小程序最有用的投票小程序微信推送里投票制作教程

“夏日非遗传承活动”网络评选投票_用户选择好用的投票小程序_最有用的投票小程序用户在使用微信投票的时候,需要功能齐全,又快捷方便的投票小程序。而“活动星投票”这款软件使用非常的方便,用户可以随时使用手机微信小程序获得线上投票服务…

医学生考研考博太卷,一篇文章轻松助力上岸——生物信息学及R语言基础知识之向量的生成(一)

考研考博太卷了,卷不过,想没想过本科发一篇文章呢? 330分考研人淘汰390分考研人这个故事,大家应该都知道吧。 本专栏带你六个月内,搞定一篇文章,本科生发文章也很容易。 在卷考研的同时,再卷一篇SCI,你就是新一任卷王。 本专栏教你不用花钱发一篇生信文章,从三个方…

带你了解软件测试是做什么的

软件测试是互联网技术中一门重要的学科,它是软件生命周期中不可或缺的一个环节,担负着把控、监督软件的质量的重任。 人才稀缺,对于求职者来说就意味着机会。但是很多想学习软件测试的人对这个学科并不了解,也不知道该如何学习&a…

Vue3的新特性

文章目录1 生命周期的变化2 使用proxy代替defineProperty2.1 Object.defineProperty()语法2.2 Proxy的语法3 Diff算法的提升3.1 以往的渲染策略3.2 Vue3的突破4 TypeScript的支持5 优化打包体积6 新的响应性 API6.1 reactive()6.2 <script setup>6.3 nextTick()6.4 react…

【半监督医学图像分割 2022 MICCAI】CLLE 论文翻译

文章目录【半监督医学图像分割 2022 MICCAI】CLLE 论文翻译摘要1. 简介2. 方法2.1 半监督框架概述2.2 监督局部对比学习2.3 下采样和块划分3. 实验4. 结论【半监督医学图像分割 2022 MICCAI】CLLE 论文翻译 论文题目&#xff1a;Semi-supervised Contrastive Learning for Labe…

Kafka 消息队列

目录主流的消息队列消息队列的应用场景缓存/肖锋解耦异步处理KafkaKafka的定义Kafka的底层基础架构Kafka分区如何保证Leader选举Kafka分区如何保证Leader和Follower数据的一致性Kafka 中消费者的消费方式Kafka 高效读写数据的原因&#xff08;高性能吞吐的原因&#xff09;&…