iis服务器助手广告广告
返回顶部
首页 > 资讯 > 服务器 >IP多播技术详解
  • 868
分享到

IP多播技术详解

tcp/ip网络服务器ip运维 2023-08-19 13:08:37 868人浏览 泡泡鱼
摘要

文章目录 前言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)路由器,以该路由器为根,建立一棵连接多播组的所有成员路由器的生成树,作为多播转发树
在这里插入图片描述


来源地址:https://blog.csdn.net/qq_72935001/article/details/128864417

--结束END--

本文标题: IP多播技术详解

本文链接: https://www.lsjlt.com/news/375487.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • IP多播技术详解
    文章目录 前言IP多播技术的相关基本概念IP多播地址和多播组 在局域网上进行硬件多播IP多播地址和多播MAC地址映射关系 在因特网上进行IP多播网际组管理协议IGMP多播路由选择协议 前言 随着计算机网络的发展和个...
    99+
    2023-08-19
    tcp/ip 网络 服务器 ip 运维
  • ×××技术详解(3)
    九、数据传输阶段   一旦完成上述4阶段的协商,PPP就开始在连接对等双方之间转发数据。每个被传送的数据报都被封装在PPP包头内,该包头将会在到达接收方之后被去除。如果在阶段1选择使用数据压缩并且在阶段4完成了协商,数据将会在被传送之间进行...
    99+
    2023-01-31
    详解 技术
  • JavaWebService技术详解
    目录WebServiceWebService简介WebService原理JAVA WebService规范(1)JAX-WS:(2)JAXM&SAAJ:(3)JAX-RS:W...
    99+
    2024-04-02
  • Java HttpClient技术详解
    目录一、HttpClient1.1、 前台系统访问后台接口的方式1.2、 什么是HttpClient1.3、 HttpClient入门案例1.3.1、 发起Get请求1.3.2、 带...
    99+
    2024-04-02
  • Java WebService技术详解
    Java WebService技术是一种用于构建分布式应用程序的技术,它允许不同的应用程序通过网络进行通信和交互。Java WebS...
    99+
    2023-08-11
    java
  • Java反射技术详解
    目录前言一、基本反射技术1.1 根据一个字符串得到一个类getClass方法Class.forNameType属性二、获取类的成员获取类中特定的构造方法调用构造方法调用类的私有方法获...
    99+
    2024-04-02
  • JDBC核心技术详解
    一、JDBC概述 1、数据的持久化 持久化(persistence):把数据保存到可掉电式存储设备中以供之后使用。大多数情况下,特别是企业级应用,数据持久化意味着将内存中的数据保存到...
    99+
    2024-04-02
  • 详解多云架构下的JAVA微服务技术解析
    目录微服务生态多云微服务架构的两种方案采用开源微服务框架适配多供应商开发框架微服务生态 微服务生态本质上是一种微服务架构模式的实现,包括微服务开发SDK,以及微服务基础设施。 目前比...
    99+
    2024-04-02
  • Java 多线程同步技术详解,Windows 平台适用!
    在多线程编程中,同步是一个非常重要的概念。在多个线程同时访问共享资源的情况下,如果没有同步,就有可能会出现竞态条件和数据不一致等问题。Java 提供了多种同步技术,本文将详细介绍 Java 多线程同步技术。 synchronized 关...
    99+
    2023-09-09
    同步 windows 教程
  • Android网络技术HttpURLConnection详解
    介绍早些时候,Android 上发送 HTTP 请求一般有 2 种方式:HttpURLConnection 和 HttpClient。不过由于 HttpClient 存在 API 数量过多、扩展困难等缺点,Android 团队越来越不建议我...
    99+
    2023-05-30
    android 网络技术 httpurlconnection
  • 详解commons-pool2池化技术
    目录一、前言二、commons-pool2池化技术剖析2.1、核心三元素2.1.1、ObjectPool2.1.2、PooledObjectFactory2.1.3、PooledOb...
    99+
    2024-04-02
  • java多线程编程技术详解和实例代码
     java多线程编程技术详解和实例代码1.   Java和他的API都可以使用并发。可以指定程序包含不同的执行线程,每个线程都具有自己的方法调用堆栈和程序计数器,使得线程在与其他线程并发地执行能够共享程序范围内...
    99+
    2023-05-31
    java 多线程 编程
  • Android Hook技术实战详解
    前些天发现了一个蛮有意思的人工智能学习网站,8个字形容一下"通俗易懂,风趣幽默",感觉非常有意思,忍不住分享一下给大家。 👉点击跳转到教程 前言: 什么是Android Hook...
    99+
    2023-09-03
    android Hook 反射 动态代理 view
  • PHP中的直播技术指南
    PHP是一种流行的脚本语言,非常适合用于开发网络应用程序。如果您需要构建一个直播业务,PHP还可以帮助您实现这一目标。本文将介绍PHP中的一些直播技术指南,帮助您了解如何利用PHP构建强大的直播应用。一、什么是直播技术?直播技术是通过网络将...
    99+
    2023-05-23
    指南 PHP 直播技术
  • PHP发送短信技术详解
    一、简介随着移动互联网的普及,短信营销越来越受到企业的关注和重视。作为一种实效性极高、成本极低、传递速度极快的宣传方式,短信营销正逐渐成为企业推销新品、掌握市场新变化的重要手段之一。PHP作为一种强大的后端语言,也可以实现短信发送的功能。本...
    99+
    2023-05-21
    PHP 发送短信 技术详解
  • 详解App保活技术实现
    目录前言黑科技进程保活原理Java 层复活进程在 native 层进行 binder 通信方式一 利用 libbinder.so 与 ActivityManagerService 通...
    99+
    2024-04-02
  • Android 中SQLite技术实例详解
    Android和iOS的数据库都是用SQLite来实现.一,SQLite数据库简介:轻量级:SQLite数据库是一个轻量级的数据库,适用于少量数据的CURD;文件本质:SQLite数据库支持大部分SQL语法,允许使用SQL语句操作数据库,其...
    99+
    2023-05-31
    android sqlite lite
  • cdn涉及的多种技术解析
    CDN(Content Delivery Network)是一种通过分布在全球各地的服务器节点来分发内容的技术。它涉及的多种技术包括...
    99+
    2023-09-09
    CDN
  • Java SpringAOP技术之注解方式详解
    目录1.配置xml扫描注解 2.配置注解3.配置文件中开启自动代理4.通知类型注解5.测试类6.结果 总结1.配置xml扫描注解  <xml ve...
    99+
    2024-04-02
  • JavaSE XML解析技术的使用详解
    文章目录 XML解析技术XML解析技术介绍Dom4j解析XML文件Dom4j解析各个节点Dom4j解析案例实战 XML解析技术 XML解析技术介绍 XML的数据作用是什么 最终需要怎样...
    99+
    2023-09-30
    xml java 数据库
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作