IPTV为什么要直连光猫
所有的信息接收者都加入到一个组内,并且一旦加入之后,流向该组地址的数据立即开始向接收者传输,组中的所有成员都能接收到数据包,这个组就是“组播组”。a) 路由器在单播路由表中查找组播源或 RP 对应的 RPF 接口(当使用信源树时,查找组播源对应的 RPF 接口,使用共享树时查找 RP 对应的 RPF 接口),某个地址对应的 RPF 接口是指从路由器向该地址发送报文时的出接口;239.0.0.0到2
最佳答案
IPTV机顶盒之所以要与光猫连接,而且必须用网线,不能用无线网络,这是因为运营商的业务模式决定的。单纯从技术层面来说,运营商的IPTV业务有组播和OTT两种模式,目前OTT模式基本被淘汰。
所谓的OTT模式,就是指IPTV业务通过互联网通道传输,这一模式最大的弊端就是会占用上网带宽。举一个简单的例子来说,100M的家庭宽带,如果用IPTV看电视直播,至少会占用20M带宽。如果用IPTV盒子看4K视频,几乎要占用50M带宽,用户正常上网可能会感觉到卡。
正是因为OTT模式会占用上网带宽,运营商才会把IPTV业务模式升级到组播模式。尤其是在一些偏远地区,宽带只有50M,OTT模式的IPTV机顶盒会占用大量带宽,用户的正常上网都会受到影响。在运营商的QoS规则中,IPTV数据优先级别高于上网数据。
相比之下,IPTV的组播模式就不会占用上网带宽。由于组播模式使用专门的通道,与上网数据是隔离的。所以,现在运营商的IPTV模式已经改造成为组播模式。组播模式,IPTV机顶盒要与光猫的IPTV端口连接,而且只能用网线连接。
组播知识点
-
随着Internet网络的不断发展,网络中交互的各种数据、语音和视频信息越来越多,同时新兴的电子商务、网上会议、网上拍卖、视频点播、远程教学等服务也在逐渐兴起。这些服务对信息安全性、有偿性、网络带宽提出了要求。
-
现代网络传输技术对以下两项目标给予更高的关注:
a) 资源发现
b) 点对多点的IP传输
-
实现这两项目标有三种解决方案:单播(Unicast)、广播(Broadcast)、组播(Multicast)
-
组播方式更适合点对多点的IP传输。
-
网络中存在信息发送者“源”,接收者A和C提出信息需求,网络采用单播方式传输信息。
-
采用单播(Unicast)方式时,系统为每个需求该信息的用户单独建立一条数据传送通路,并为该用户发送一份独立的拷贝信息。由于网络中传输的信息量和需求该信息的用户量成正比,因此当需求该信息的用户量庞大时,网络中将出现多份相同信息流。此时,带宽将成为重要瓶颈,单播方式较适合用户稀少的网络,不利于信息规模化发送。
-
网络中存在信息发送者“源”,接收者A和C提出信息需求,网络采用单播方式传输信息。
-
采用单播(Unicast)方式时,系统为每个需求该信息的用户单独建立一条数据传送通路,并为该用户发送一份独立的拷贝信息。由于网络中传输的信息量和需求该信息的用户量成正比,因此当需求该信息的用户量庞大时,网络中将出现多份相同信息流。此时,带宽将成为重要瓶颈,单播方式较适合用户稀少的网络,不利于信息规模化发送。
-
组播的优势主要在于:
a) 提高效率:降低网络流量、减轻服务器和CPU负荷。
b) 优化性能:减少冗余流量、节约网络带宽、降低网络负载。
c) 分布式应用:使多点应用成为可能。
-
组播技术有效地解决了单点发送多点接收的问题,实现了IP网络中点到多点的高效数据传送。利用网络的组播特性可以方便地提供一些新的增值业务,包括在线直播、网络电视、远程教育、远程医疗、网络电台、实时视/音频会议等互联网的信息服务领域。
-
组播技术有效地解决了单点发送多点接收的问题,实现了IP网络中点到多点的高效数据传送。但由于组播技术是基于UDP的,所以同时也存在着不足之处:
a) 尽力而为:报文丢失是不可避免的。因此组播应用程序不能依赖组播网络进行可靠性保证,必须针对组播网络的这个特点进行特别设计。“可靠组播”目前仍然处于研究阶段。
b) 没有拥塞避免机制:缺少TCP窗口机制和慢启动机制,组播可能会出现拥塞。如果可能的话,组播应用程序应该尝试检测避免拥塞。
c) 报文重复:某些组播协议的特殊机制(如Assert机制和SPT切换机制)可能会造成偶尔的数据包的重复。组播应用程序应该容忍这种现象。
d) 报文失序:同样组播协议有的时候会造成报文到达的次序错乱,组播应用程序必须自己采用某种手段进行纠正(比如缓冲池机制等)。
-
单播数据传输过程中,一个数据包传输的路径是从源地址路由到目的地址,利用“逐跳”(hop-by-hop)的原理在IP网络中传输。然而在IP组播环境中,数据包的目的地址不是一个,而是一组,形成组地址。所有的信息接收者都加入到一个组内,并且一旦加入之后,流向该组地址的数据立即开始向接收者传输,组中的所有成员都能接收到数据包,这个组就是“组播组”。
-
根据IANA(Internet Assigned Numbers Authority)规定,组播报文的目的地址使用D类IP地址,D类地址不能出现在IP报文的源IP地址字段。
-
D类组播地址范围是从224.0.0.0到239.255.255.255 。
-
ASM模型:ASM模型就是任意源组播模型。在该模型中,任意发送者都可以成为组播源,向某组播组地址发送信息。众多接收者通过加入由该地址标识的主机组,从而接收到发往该组播组的所有信息。在ASM模型中,接收者无法预先知道组播源的位置,接收者可以在任意时间加入或离开该主机组。
-
SFM模型:SFM模型继承了ASM模型,从发送者角度来看,组播组成员关系完全相同。SFM在功能上对ASM进行了扩展:上层软件对接收到的组播报文的源地址进行检查,允许或禁止来自某些组播源的报文通过。最终,接收者只能接收到来自部分组播源的数据。从接收者角度来看,只有部分组播源是有效的,组播源经过了筛选。
-
SSM模型:在现实生活中,用户可能仅对某些源发送的组播信息感兴趣,而不愿接收其它源发送的信息。SSM模型为用户提供了一种能够在客户端指定信源的传输服务。
-
SSM模型和ASM模型的根本区别是接收者已经通过其他手段预先知道了组播源的具体位置。SSM使用和ASM不同的组播地址范围,直接在接收者和其指定的组播源之间建立专用的组播转发路径。
-
永久组地址:IANA为路由协议预留的组播地址,用于标识一组特定的网络设备(也称为保留组播组)。永久组地址保持不变,组成员的数量可以是任意的,甚至可以为零。如224.0.0.5是为OSPF路由协议中预留的组播地址。
-
临时组地址:为用户组播组临时分配的IP地址,组成员的数量一旦为零,即取消。
-
224.0.0.0 到 224.0.0.255 为 IANA 预留的永久组地址,地址 224.0.0.0 保留不做分配,其它地址供路由协议及拓扑查找和维护协议使用。该范围内的地址属于局部范畴,不论生存时间字段(TTL)值是多少,都不会被路由器转发;
-
224.0.1.0到231.255.255.255,233.0.0.0到238.255.255.255为用户可用的ASM临时组地址,在全网范围内有效;
-
232.0.0.0到232.255.255.255,为用户可用的SSM临时组地址,全网范围内有效。
-
239.0.0.0到239.255.255.255,用户可用的ASM临时组地址,仅在特定的本地管理域内有效,称为本地管理组播地址。本地管理组播地址属于私有地址,在不同的管理域内使用相同的本地管理组播地址不会导致冲突。
-
以太网传输单播IP报文的时候,目的MAC地址使用的是接收者的MAC地址。但是在传输组播报文时,传输目的不再是一个具体的接收者,而是一个成员不确定的组,所以使用的是组播MAC地址。
-
组播MAC地址用于在链路层上标识属于同一组播组的接收者。
-
IANA规定,组播MAC地址的高24bit为0x01005e,第25bit固定为0,低23bit为组播IP地址的低23bit。
-
组播协议包括用于主机注册的组播组管理协议,和用于组播选路转发的组播路由协议。
-
IGMP(Internet Group Management Protocol)在接收者主机和组播路由器之间运行,该协议定义了主机与路由器之间建立和维护组播成员关系的机制。
-
组播路由器之间运行组播路由协议,组播路由协议用于建立和维护组播路由,并正确、高效地转发组播数据包。
-
对于ASM模型,可以将组播路由分为域内和域间两大类。
-
组播路由形成了一个从数据源到多个接收端的单向无环数据传输路径,即组播分发树。
-
组播分发树的两个基本类型:源路径树和共享树。
-
源路径树:以组播源作为树根,将组播源到每一个接收者的最短路径结合起来构成的转发树。由于源路径树使用的是从组播源到接收者的最短路径,因此也称为最短路径树(Shortest Path Tree,SPT)。对于某个组,网络要为任何一个向该组发送报文的组播源建立一棵树。
-
共享树:以某个路由器作为路由树的树根,该路由器称为汇集点(Rendezvous Point,RP),将 RP 到所有接收者的最短路径结合起来构成转发树。
-
使用共享树时,对应某个组,网络中只有一棵树。所有的组播源和接收者都使用这棵树来收发报文,组播源先向树根发送数据报文,之后报文又向下转发到达所有的接收者。
-
源路径树以组播源作为树根,将组播源到每一个接收者的最短路径结合起来构成的转发树。
-
源路径树使用的是从组播源到接收者的最短路径,也称为最短路径树(shortest path tree,SPT)。对于某个组,网络要为任何一个向该组发送报文的组播源建立一棵树。
-
共享树以某个路由器作为路由树的树根,该路由器称为汇集点(Rendezvous Point,RP),将 RP 到所有接收者的最短路径结合起来构成转发树。使用共享树时,对应某个组,网络中只有一棵树。所有的组播源和接收者都使用这棵树来收发报文,组播源先向树根发送数据报文,之后报文又向下转发到达所有的接收者。
-
源路径树的优点是能构造组播源和接收者之间的最短路径,使端到端的延迟达到最小;但是付出的代价是,在路由器中必须为每个组播源保存路由信息,这样会占用大量的系统资源,路由表的规模也比较大。
-
共享树的最大优点是路由器中保留的状态可以很少,缺点是组播源发出的报文要先经过 RP,再到达接收者,经由的路径通常并非最短,而且对 RP 的可靠性和处理能力要求很高。
-
单播报文的转发过程中,路由器并不关心源地址,只关心报文中的目的地址,通过目的地址决定向哪个接口转发。
-
在组播中,报文是发送给一组接收者的,这些接收者用一个逻辑地址标识。路由器在接收到报文后,必须根据源和目的地址确定出上游(指向组播源)和下游方向,把报文沿着远离组播源的方向进行转发。这个过程称作 RPF(Reverse Path Forwarding,逆向路径转发)。
-
RPF 执行过程中会用到原有的单播路由表以确定上游和下游的邻接结点。只有当报文是从上游邻接结点对应的接口(称作 RPF 接口)到达时,才向下游转发。
-
RPF 的作用除了可以正确地按照组播路由的配置转发报文外,还能避免由于各种原因造成的环路,环路避免在组播路由中是一个非常重要的问题。
-
RPF 的主体是 RPF 检查,路由器收到组播报文后,先对报文进行 RPF 检查,只有检查通过才转发,否则丢弃。RPF 检查过程如下:
a) 路由器在单播路由表中查找组播源或 RP 对应的 RPF 接口(当使用信源树时,查找组播源对应的 RPF 接口,使用共享树时查找 RP 对应的 RPF 接口),某个地址对应的 RPF 接口是指从路由器向该地址发送报文时的出接口;
b) 如果组播报文是从 RPF 接口接收下来的,则 RPF 检查通过,报文向下游接口转发;
c) 否则,丢弃该报文。
-
RPF检查的过程实际上是查找单播路由表的过程。
-
路由器接收到组播报文后,后查找单播路由表,检查到达组播源的出接口是否与接收到组播报文接口一致。如果一致则认为合法,如果不一致则认为从错误接口收到报文,RFP检查失败,丢弃报文。
-
什么是组播?
组播组使用一个IP组播地址标识,接收者A和C两个信息接收者加入该组播组后从而可以接收发往该组播组的数据。组播源仅发送一次信息,借助组播路由协议为组播数据包建立树型路由,被传递的信息在尽可能远的分叉路口才开始复制和分发。相同的组播数据流在每一条链路上最多仅有一份。
- 组播地址结构是怎样的?
D类组播地址范围是从224.0.0.0到239.255.255.255 。根据地址有效性分为:永久组地址和临时组地址。永久组地址 IANA为路由协议预留的组播地址,标识一组特定的网络设备。永久组地址保持不变,组成员的数量可以是任意的,甚至可以为零。临时组地址是为用户组播组临时分配的IP地址,组成员的数量一旦为零,即取消。
- 组播相关协议有哪些?
组播协议包括用于主机注册的组播组管理协议(IGMP)和用于组播选路转发的组播路由协议。组播路由协议分为域内组播路由协议和域间组播路由协议。域内组播路由协议有PIM-SM、PIM-DM、DVMRP,域间组播路由协议有MSDP、MBGP。
- 什么是组播分发树?组播分发树的类型有哪些?
组播路由形成了一个从数据源到多个接收端的单向无环数据传输路径,即组播分发树。组播分发树有两类:源路径树以组播源作为树根,将组播源到每一个接收者的最短路径结合起来构成的转发树,也称为最短路径树。共享树以某个路由器作为路由树的树根,RP 到所有接收者的最短路结合起来构成转发树。
- 组播转发机制RPF原理是怎样的?
RPF执行过程中会用到原有的单播路由表以确定上游和下游的邻接结点。只有当报文是从上游邻接结点对应的接口(称作 RPF 接口)到达时,才向下游转发。具体过程如下:路由器接收到组播报文后在单播路由表中查找到组播报文源地址的路由,如果该路由的出接口就是组播报文的入接口,RPF成功,否则RPF失败,报文丢弃。
python组播示例
组播是一种网络通信模式,它可以让一个主机或路由器发送数据包到一个或多个组播组,也就是一组共享相同兴趣的主机或路由器。组播可以节省网络带宽,提高效率,实现一些特殊的应用,比如视频会议,流媒体,网络游戏等。
要使用组播,你需要用Python的socket模块创建一个UDP套接字,并设置一些特殊的选项,比如组播地址,端口号,时间生存(TTL),接口地址等。你还需要用struct模块打包和解包一些二进制数据,比如IP地址和端口号。
下面是一个简单的组播的示例,它包括一个发送者和一个接收者。发送者会向一个组播地址发送一条消息,接收者会加入这个组播组,并接收并打印这条消息。
# 发送者
import socket
import struct
# 创建一个UDP套接字
sock = socket.socket(socket.AF_INET, socket.SOCK_DGRAM)
# 设置组播地址和端口号
mcast_addr = '224.1.1.1'
mcast_port = 5007
# 设置时间生存(TTL)为1,表示数据包只在本地网络内传输
ttl = struct.pack('b', 1)
sock.setsockopt(socket.IPPROTO_IP, socket.IP_MULTICAST_TTL, ttl)
# 发送一条消息到组播地址
message = 'Hello, multicast!'
sock.sendto(message.encode(), (mcast_addr, mcast_port))
# 关闭套接字
sock.close()
# 接收者
import socket
import struct
# 创建一个UDP套接字
sock = socket.socket(socket.AF_INET, socket.SOCK_DGRAM)
# 设置套接字可以重用地址和端口
sock.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, 1)
# 绑定到组播地址和端口号
sock.bind((mcast_addr, mcast_port))
# 构造一个加入组播组的请求
mreq = struct.pack('4sL', socket.inet_aton(mcast_addr), socket.INADDR_ANY)
# 设置套接字加入组播组
sock.setsockopt(socket.IPPROTO_IP, socket.IP_ADD_MEMBERSHIP, mreq)
# 接收并打印消息
data, addr = sock.recvfrom(1024)
print('Received {} from {}'.format(data.decode(), addr))
# 关闭套接字
sock.close()
如果你想运行这个示例,你可以在两个终端中分别执行发送者和接收者的代码,并选择你自己的接口地址(必须和接收组播数据的接口相同)。你也可以修改组播地址和端口号,只要它们在有效的范围内。
开放原子开发者工作坊旨在鼓励更多人参与开源活动,与志同道合的开发者们相互交流开发经验、分享开发心得、获取前沿技术趋势。工作坊有多种形式的开发者活动,如meetup、训练营等,主打技术交流,干货满满,真诚地邀请各位开发者共同参与!
更多推荐
所有评论(0)