《TCP/IP详解 卷一:协议》读书笔记 - 11 广播和多播

本贴最后更新于 2956 天前,其中的信息可能已经沧海桑田

#广播和多播
根据 IP 地址对象的个数可以分为:单播地址,广播地址,多播地址。

广播地址和多播地址仅应用于 UDP(TCP 是面向连接的协议,因此只能单播) 。
下面介绍以下信道传送过滤帧的过程。

  • 网卡过滤由信道传送过来的帧,通常网卡仅接收目的地址为网卡物理地址或广播多播地址的帧(在以太网中,地址最高字节最低位设置为 12 表示是一个多播地址,01:00:00:00:00:00)。若接收后就将它传往设备驱动程序(若校验和错误,会被抛弃)。
  • 设备驱动程序进行另外的帧过滤,首先帧中必须指定使用的协议(IP、ARP 等);其次对多播地址需要检测该主机是否属于该多播组。若接收后将数据帧根据协议传给下一层。下面以下一层为 IP 进行说明。
  • IP 根据 IP 报首中的源地址和目的地址进行过滤。若正常,将数据报传送给下一层,如 UDP
  • UDP 根据目的端口号(有时还根据源端口进行过滤)。如果当前没有进程使用该目的端口,就丢弃数据报并产生 ICMP 不可达(若校验和出错同样也丢弃)。

根据上述的过程,我们知道广播增加了对广播地址不感兴趣的主机的处理负荷,因为只有到 UDP 层时,才能发现本机对该端口数据不感兴趣。
因此,多播的出现减少了这种负担,设备驱动程序就能进行过滤。


##广播
###受限的广播
受限的广播地址是指 255.255.255.255,主机不知道目的主机的 IP 地址及网络掩码。
这样的数据报仅出现在本地网络中,路由器不转发目的地址为受限广播地址的数据报。

一个未解决的问题:
若主机是多接口,那么广播地址的数据报应当发送到每个相连的接口上?还是发往主机中支持广播的所有接口?
大多数 BSD 系统将 255.255.255.255 看错是配置后的第一个接口的广播地址。

###指向网络的广播
指向网络的广播地址是主机号全 1 的地址。A 类地址的广播地址为:netid.255.255.255。
路由器需转发指向网络的广播地址。

###指向子网的广播
指向子网的广播地址是主机号为全 1,且具有特定子网号的地址,需要知道子网的掩码。

###指向所有子网的广播
指向所有子网的广播是子网号和主机号全为 1 的地址,需要知道子网的掩码,若无掩码,则该地址是一个指向网络的地址。


##多播
IP 多播提供两类服务:

  • 向多个目的地址传送数据。
  • 客户端对服务器的请求,如:无盘工作站需要确定启动引导服务器。

###多播组地址

D 类地址为多播地址,包括 4bit 网络号(1110)和 28bit 多播组 ID,范围 224.0.0.0 到 239.225.225.225

能够接收发往一个特定多播组地址数据的主机集合称为主机组。一个主机组可以跨多个网络。主机组中成员可以随时加入或离开主机组。
IANA 确定了一些永久主机组(和常用端口原理类似):224.0.0.1 代表该子网内所有系统组,224.0.0.2 代表该子网内所有路由器组等等。

###多播组地址到以太网地址的转换
IANA 拥有一块以太网地址,高 24bit 为 00:00:5e,其指定以太网多播地址首字节必须是 01,因此多播地址对应的以太网地址范围是 01:00:5e:00:00:00 到 01:00:5e:7f:ff:ff。

再把 IP 地址多播 ID 号 23bit(28-5=23 忽略最高 5bit)映射到以太网地址中的低 23bit(48-24=24,高 1bit 不用)。

但是这样会产生多个 IP 广播地址会映射到同一个以太网地址。因此设备驱动程序或 IP 层需要对数据报进行过滤。但是这样消耗依然比广播少得多。

注意,同一主机上可能存在多个属于同一多播组的进程,因此在收到多播数据报时,必须向属于多播组的每个进程传送一份复制。

相关帖子

欢迎来到这里!

我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。

注册 关于
请输入回帖内容 ...

推荐标签 标签

  • Hibernate

    Hibernate 是一个开放源代码的对象关系映射框架,它对 JDBC 进行了非常轻量级的对象封装,使得 Java 程序员可以随心所欲的使用对象编程思维来操纵数据库。

    39 引用 • 103 回帖 • 683 关注
  • 快应用

    快应用 是基于手机硬件平台的新型应用形态;标准是由主流手机厂商组成的快应用联盟联合制定;快应用标准的诞生将在研发接口、能力接入、开发者服务等层面建设标准平台;以平台化的生态模式对个人开发者和企业开发者全品类开放。

    15 引用 • 127 回帖
  • CodeMirror
    1 引用 • 2 回帖 • 115 关注
  • Google

    Google(Google Inc.,NASDAQ:GOOG)是一家美国上市公司(公有股份公司),于 1998 年 9 月 7 日以私有股份公司的形式创立,设计并管理一个互联网搜索引擎。Google 公司的总部称作“Googleplex”,它位于加利福尼亚山景城。Google 目前被公认为是全球规模最大的搜索引擎,它提供了简单易用的免费服务。不作恶(Don't be evil)是谷歌公司的一项非正式的公司口号。

    49 引用 • 192 回帖
  • 音乐

    你听到信仰的声音了么?

    59 引用 • 509 回帖
  • Tomcat

    Tomcat 最早是由 Sun Microsystems 开发的一个 Servlet 容器,在 1999 年被捐献给 ASF(Apache Software Foundation),隶属于 Jakarta 项目,现在已经独立为一个顶级项目。Tomcat 主要实现了 JavaEE 中的 Servlet、JSP 规范,同时也提供 HTTP 服务,是市场上非常流行的 Java Web 容器。

    162 引用 • 529 回帖
  • Python

    Python 是一种面向对象、直译式电脑编程语言,具有近二十年的发展历史,成熟且稳定。它包含了一组完善而且容易理解的标准库,能够轻松完成很多常见的任务。它的语法简捷和清晰,尽量使用无异义的英语单词,与其它大多数程序设计语言使用大括号不一样,它使用缩进来定义语句块。

    535 引用 • 672 回帖
  • CentOS

    CentOS(Community Enterprise Operating System)是 Linux 发行版之一,它是来自于 Red Hat Enterprise Linux 依照开放源代码规定释出的源代码所编译而成。由于出自同样的源代码,因此有些要求高度稳定的服务器以 CentOS 替代商业版的 Red Hat Enterprise Linux 使用。两者的不同在于 CentOS 并不包含封闭源代码软件。

    238 引用 • 224 回帖 • 2 关注
  • Kubernetes

    Kubernetes 是 Google 开源的一个容器编排引擎,它支持自动化部署、大规模可伸缩、应用容器化管理。

    108 引用 • 54 回帖 • 1 关注
  • Bug

    Bug 本意是指臭虫、缺陷、损坏、犯贫、窃听器、小虫等。现在人们把在程序中一些缺陷或问题统称为 bug(漏洞)。

    77 引用 • 1741 回帖
  • jsoup

    jsoup 是一款 Java 的 HTML 解析器,可直接解析某个 URL 地址、HTML 文本内容。它提供了一套非常省力的 API,可通过 DOM,CSS 以及类似于 jQuery 的操作方法来取出和操作数据。

    6 引用 • 1 回帖 • 457 关注
  • IPFS

    IPFS(InterPlanetary File System,星际文件系统)是永久的、去中心化保存和共享文件的方法,这是一种内容可寻址、版本化、点对点超媒体的分布式协议。请浏览 IPFS 入门笔记了解更多细节。

    20 引用 • 245 回帖 • 228 关注
  • Logseq

    Logseq 是一个隐私优先、开源的知识库工具。

    Logseq is a joyful, open-source outliner that works on top of local plain-text Markdown and Org-mode files. Use it to write, organize and share your thoughts, keep your to-do list, and build your own digital garden.

    4 引用 • 55 回帖 • 7 关注
  • OAuth

    OAuth 协议为用户资源的授权提供了一个安全的、开放而又简易的标准。与以往的授权方式不同之处是 oAuth 的授权不会使第三方触及到用户的帐号信息(如用户名与密码),即第三方无需使用用户的用户名与密码就可以申请获得该用户资源的授权,因此 oAuth 是安全的。oAuth 是 Open Authorization 的简写。

    36 引用 • 103 回帖 • 8 关注
  • HHKB

    HHKB 是富士通的 Happy Hacking 系列电容键盘。电容键盘即无接点静电电容式键盘(Capacitive Keyboard)。

    5 引用 • 74 回帖 • 405 关注
  • CloudFoundry

    Cloud Foundry 是 VMware 推出的业界第一个开源 PaaS 云平台,它支持多种框架、语言、运行时环境、云平台及应用服务,使开发人员能够在几秒钟内进行应用程序的部署和扩展,无需担心任何基础架构的问题。

    5 引用 • 18 回帖 • 150 关注
  • 负能量

    上帝为你关上了一扇门,然后就去睡觉了....努力不一定能成功,但不努力一定很轻松 (° ー °〃)

    85 引用 • 1201 回帖 • 454 关注
  • VirtualBox

    VirtualBox 是一款开源虚拟机软件,最早由德国 Innotek 公司开发,由 Sun Microsystems 公司出品的软件,使用 Qt 编写,在 Sun 被 Oracle 收购后正式更名成 Oracle VM VirtualBox。

    10 引用 • 2 回帖 • 7 关注
  • BAE

    百度应用引擎(Baidu App Engine)提供了 PHP、Java、Python 的执行环境,以及云存储、消息服务、云数据库等全面的云服务。它可以让开发者实现自动地部署和管理应用,并且提供动态扩容和负载均衡的运行环境,让开发者不用考虑高成本的运维工作,只需专注于业务逻辑,大大降低了开发者学习和迁移的成本。

    19 引用 • 75 回帖 • 621 关注
  • 以太坊

    以太坊(Ethereum)并不是一个机构,而是一款能够在区块链上实现智能合约、开源的底层系统。以太坊是一个平台和一种编程语言 Solidity,使开发人员能够建立和发布下一代去中心化应用。 以太坊可以用来编程、分散、担保和交易任何事物:投票、域名、金融交易所、众筹、公司管理、合同和知识产权等等。

    34 引用 • 367 回帖 • 2 关注
  • 工具

    子曰:“工欲善其事,必先利其器。”

    273 引用 • 679 回帖
  • SQLServer

    SQL Server 是由 [微软] 开发和推广的关系数据库管理系统(DBMS),它最初是由 微软、Sybase 和 Ashton-Tate 三家公司共同开发的,并于 1988 年推出了第一个 OS/2 版本。

    19 引用 • 31 回帖 • 3 关注
  • Webswing

    Webswing 是一个能将任何 Swing 应用通过纯 HTML5 运行在浏览器中的 Web 服务器,详细介绍请看 将 Java Swing 应用变成 Web 应用

    1 引用 • 15 回帖 • 635 关注
  • Ruby

    Ruby 是一种开源的面向对象程序设计的服务器端脚本语言,在 20 世纪 90 年代中期由日本的松本行弘(まつもとゆきひろ/Yukihiro Matsumoto)设计并开发。在 Ruby 社区,松本也被称为马茨(Matz)。

    7 引用 • 31 回帖 • 177 关注
  • 深度学习

    深度学习(Deep Learning)是机器学习的分支,是一种试图使用包含复杂结构或由多重非线性变换构成的多个处理层对数据进行高层抽象的算法。

    40 引用 • 40 回帖
  • 友情链接

    确认过眼神后的灵魂连接,站在链在!

    24 引用 • 373 回帖 • 3 关注
  • 互联网

    互联网(Internet),又称网际网络,或音译因特网、英特网。互联网始于 1969 年美国的阿帕网,是网络与网络之间所串连成的庞大网络,这些网络以一组通用的协议相连,形成逻辑上的单一巨大国际网络。

    96 引用 • 330 回帖