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

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

#广播和多播
根据 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 层需要对数据报进行过滤。但是这样消耗依然比广播少得多。

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

相关帖子

欢迎来到这里!

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

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

推荐标签 标签

  • 导航

    各种网址链接、内容导航。

    43 引用 • 177 回帖
  • 设计模式

    设计模式(Design pattern)代表了最佳的实践,通常被有经验的面向对象的软件开发人员所采用。设计模式是软件开发人员在软件开发过程中面临的一般问题的解决方案。这些解决方案是众多软件开发人员经过相当长的一段时间的试验和错误总结出来的。

    200 引用 • 120 回帖
  • Solidity

    Solidity 是一种智能合约高级语言,运行在 [以太坊] 虚拟机(EVM)之上。它的语法接近于 JavaScript,是一种面向对象的语言。

    3 引用 • 18 回帖 • 432 关注
  • 开源

    Open Source, Open Mind, Open Sight, Open Future!

    410 引用 • 3588 回帖
  • Shell

    Shell 脚本与 Windows/Dos 下的批处理相似,也就是用各类命令预先放入到一个文件中,方便一次性执行的一个程序文件,主要是方便管理员进行设置或者管理用的。但是它比 Windows 下的批处理更强大,比用其他编程程序编辑的程序效率更高,因为它使用了 Linux/Unix 下的命令。

    124 引用 • 74 回帖
  • 生活

    生活是指人类生存过程中的各项活动的总和,范畴较广,一般指为幸福的意义而存在。生活实际上是对人生的一种诠释。生活包括人类在社会中与自己息息相关的日常活动和心理影射。

    230 引用 • 1454 回帖 • 1 关注
  • OneNote
    1 引用 • 3 回帖 • 1 关注
  • SMTP

    SMTP(Simple Mail Transfer Protocol)即简单邮件传输协议,它是一组用于由源地址到目的地址传送邮件的规则,由它来控制信件的中转方式。SMTP 协议属于 TCP/IP 协议簇,它帮助每台计算机在发送或中转信件时找到下一个目的地。

    4 引用 • 18 回帖 • 638 关注
  • ActiveMQ

    ActiveMQ 是 Apache 旗下的一款开源消息总线系统,它完整实现了 JMS 规范,是一个企业级的消息中间件。

    19 引用 • 13 回帖 • 678 关注
  • 负能量

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

    88 引用 • 1235 回帖 • 416 关注
  • 快应用

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

    15 引用 • 127 回帖
  • 京东

    京东是中国最大的自营式电商企业,2015 年第一季度在中国自营式 B2C 电商市场的占有率为 56.3%。2014 年 5 月,京东在美国纳斯达克证券交易所正式挂牌上市(股票代码:JD),是中国第一个成功赴美上市的大型综合型电商平台,与腾讯、百度等中国互联网巨头共同跻身全球前十大互联网公司排行榜。

    14 引用 • 102 回帖 • 318 关注
  • PostgreSQL

    PostgreSQL 是一款功能强大的企业级数据库系统,在 BSD 开源许可证下发布。

    22 引用 • 22 回帖 • 1 关注
  • SVN

    SVN 是 Subversion 的简称,是一个开放源代码的版本控制系统,相较于 RCS、CVS,它采用了分支管理系统,它的设计目标就是取代 CVS。

    29 引用 • 98 回帖 • 687 关注
  • Outlook
    1 引用 • 5 回帖 • 1 关注
  • 微信

    腾讯公司 2011 年 1 月 21 日推出的一款手机通讯软件。用户可以通过摇一摇、搜索号码、扫描二维码等添加好友和关注公众平台,同时可以将自己看到的精彩内容分享到微信朋友圈。

    132 引用 • 796 回帖
  • ZooKeeper

    ZooKeeper 是一个分布式的,开放源码的分布式应用程序协调服务,是 Google 的 Chubby 一个开源的实现,是 Hadoop 和 HBase 的重要组件。它是一个为分布式应用提供一致性服务的软件,提供的功能包括:配置维护、域名服务、分布式同步、组服务等。

    59 引用 • 29 回帖 • 3 关注
  • Linux

    Linux 是一套免费使用和自由传播的类 Unix 操作系统,是一个基于 POSIX 和 Unix 的多用户、多任务、支持多线程和多 CPU 的操作系统。它能运行主要的 Unix 工具软件、应用程序和网络协议,并支持 32 位和 64 位硬件。Linux 继承了 Unix 以网络为核心的设计思想,是一个性能稳定的多用户网络操作系统。

    951 引用 • 943 回帖
  • 又拍云

    又拍云是国内领先的 CDN 服务提供商,国家工信部认证通过的“可信云”,乌云众测平台认证的“安全云”,为移动时代的创业者提供新一代的 CDN 加速服务。

    20 引用 • 37 回帖 • 571 关注
  • Solo

    Solo 是一款小而美的开源博客系统,专为程序员设计。Solo 有着非常活跃的社区,可将文章作为帖子推送到社区,来自社区的回帖将作为博客评论进行联动(具体细节请浏览 B3log 构思 - 分布式社区网络)。

    这是一种全新的网络社区体验,让热爱记录和分享的你不再感到孤单!

    1440 引用 • 10067 回帖 • 493 关注
  • 小说

    小说是以刻画人物形象为中心,通过完整的故事情节和环境描写来反映社会生活的文学体裁。

    31 引用 • 108 回帖
  • GitLab

    GitLab 是利用 Ruby 一个开源的版本管理系统,实现一个自托管的 Git 项目仓库,可通过 Web 界面操作公开或私有项目。

    46 引用 • 72 回帖
  • RESTful

    一种软件架构设计风格而不是标准,提供了一组设计原则和约束条件,主要用于客户端和服务器交互类的软件。基于这个风格设计的软件可以更简洁,更有层次,更易于实现缓存等机制。

    30 引用 • 114 回帖 • 7 关注
  • 博客

    记录并分享人生的经历。

    273 引用 • 2388 回帖
  • 星云链

    星云链是一个开源公链,业内简单的将其称为区块链上的谷歌。其实它不仅仅是区块链搜索引擎,一个公链的所有功能,它基本都有,比如你可以用它来开发部署你的去中心化的 APP,你可以在上面编写智能合约,发送交易等等。3 分钟快速接入星云链 (NAS) 测试网

    3 引用 • 16 回帖
  • PWL

    组织简介

    用爱发电 (Programming With Love) 是一个以开源精神为核心的民间开源爱好者技术组织,“用爱发电”象征开源与贡献精神,加入组织,代表你将遵守组织的“个人开源爱好者”的各项条款。申请加入:用爱发电组织邀请帖
    用爱发电组织官网:https://programmingwithlove.stackoverflow.wiki/

    用爱发电组织的核心驱动力:

    • 遵守开源守则,体现开源&贡献精神:以分享为目的,拒绝非法牟利。
    • 自我保护:使用适当的 License 保护自己的原创作品。
    • 尊重他人:不以各种理由、各种漏洞进行未经允许的抄袭、散播、洩露;以礼相待,尊重所有对社区做出贡献的开发者;通过他人的分享习得知识,要留下足迹,表示感谢。
    • 热爱编程、热爱学习:加入组织,热爱编程是首当其要的。我们欢迎热爱讨论、分享、提问的朋友,也同样欢迎默默成就的朋友。
    • 倾听:正确并恳切对待、处理问题与建议,及时修复开源项目的 Bug ,及时与反馈者沟通。不抬杠、不无视、不辱骂。
    • 平视:不诋毁、轻视、嘲讽其他开发者,主动提出建议、施以帮助,以和谐为本。只要他人肯努力,你也可能会被昔日小看的人所超越,所以请保持谦虚。
    • 乐观且活跃:你的努力决定了你的高度。不要放弃,多年后回头俯瞰,才会发现自己已经成就往日所仰望的水平。积极地将项目开源,帮助他人学习、改进,自己也会获得相应的提升、成就与成就感。
    1 引用 • 487 回帖 • 1 关注
  • abitmean

    有点意思就行了

    31 关注