CN114945000A - 一种组播报文传输方法、位转发路由器及存储介质 - Google Patents
一种组播报文传输方法、位转发路由器及存储介质 Download PDFInfo
- Publication number
- CN114945000A CN114945000A CN202110168399.4A CN202110168399A CN114945000A CN 114945000 A CN114945000 A CN 114945000A CN 202110168399 A CN202110168399 A CN 202110168399A CN 114945000 A CN114945000 A CN 114945000A
- Authority
- CN
- China
- Prior art keywords
- message
- ipv6bier
- ipv6
- bfr
- service
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Granted
Links
Images
Classifications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L45/00—Routing or path finding of packets in data switching networks
- H04L45/16—Multipoint routing
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L45/00—Routing or path finding of packets in data switching networks
- H04L45/74—Address processing for routing
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L61/00—Network arrangements, protocols or services for addressing or naming
Landscapes
- Engineering & Computer Science (AREA)
- Computer Networks & Wireless Communication (AREA)
- Signal Processing (AREA)
- Data Exchanges In Wide-Area Networks (AREA)
Abstract
本发明公开了一种组播报文传输方法、位转发路由器及存储介质,包括:BFR接收IP组播报文;BFR进行组播报文复制,进行IPv6BIER报文封装并转发,其中,所述IPv6BIER报文中IPv6源地址设置为BFIR的网络前缀以及业务ID,IPv6目的地址设置为下一跳BFR的MPRA。BFR接收IPv6BIER报文;BFR根据网络前缀或业务ID、BFR的MPRA之一或者其组合对所述IPv6BIER报文进行处理。采用本发明,BIER封装简化并嵌入IPv6头部封装,形成基于IPv6的BIER转发模式。IPv6目的地址单独规划用于组播IPv6BIER转发预留,可在IPv6网络中插花部署BIER转发,组播数据转发时不再需要携带VPN标签,避免了占用32bit报文头部空间。扩展网络编程应用范围;充分利用IPv6丰富扩展能力;可以使IPv6网络平滑升级部署。
Description
技术领域
本发明涉及无线通信技术领域,特别涉及一种组播报文传输方法、位转发路由器及存储介质。
背景技术
组播作为一种与单播和广播并列的通信方式,通过使用特定的组播地址,将数据包传输到一个组播组内的所有的设备。当某一设备向一组设备发送数据时,不必向每个设备都发送该数据,而是将该数据发送到一个特定的组播地址,所有加入该组播组的设备均可以收到该数据。对发送端设备而言,数据只需发送一次即可以发送到所有接收者。利用组播技术可方便开展一些网络业务,包括电视直播、远程教育、远程医疗、网络电台、多媒体会议、视频监控等互联网的信息服务。
现有技术的不足在于,在IPv6(互联网协议第6版,Internet Protocol Version6)网络承载组播流量时,在转发组播数据时报文头部空间不能充分利用。
发明内容
本发明提供了一种组播报文传输方法、位转发路由器及存储介质,用以解决在转发组播数据时报文头部空间不能充分利用的问题。
本发明提供以下技术方案:
一种组播报文传输方法,包括:
BFR接收IP组播报文;
BFR进行组播报文复制,进行IPv6 BIER报文封装并转发,其中,所述IPv6BIER报文中IPv6源地址设置为BFIR的网络前缀以及业务ID,IPv6目的地址设置为下一跳BFR的MPRA。
实施中,在IPv6扩展报文头部位置通过在Destination Option Header增加一种类型Option来设置所述IPv6 BIER报文头部。
实施中,所述IPv6 BIER报文包括以下信息之一或者其组合:
BSL、SD、SI、RSV、TTL、Entropy、DSCP、Ver、OAM、BitString。
实施中,所述IPv6 BIER报文包括以下设置之一或者其组合:
用显式的BSL、SD以及SI替换BIFT-id字段;
显式BSL字段标识BitString长度;
原有BSL字段设置为保留字段;
TC设置为保留字段;
S flag设置为保留字段;
Nibble设置为保留字段;
Proto设置为保留字段;
BFIR-id设置为保留字段。
实施中,所述IPv6 BIER报文包括以下信息之一或者其组合:
BSL为BitString的长度;
SD为BIER子域标识;
SI为BIER集合标识;
TTL为BIER报文生命周期值;
Ver为协议版本号;
Entropy为用于支持ECMP路径选择;
OAM为用于BIER转发性能测量标识;
RSV为保留位,当前不用缺省为0;
DSCP为标识差分服务,通过编码值来区分优先级;
BitStirng为用来标识该BIER域出口节点的位集合。
实施中,进一步包括:
I-PMSI和S-PMSI AD路由的PTA属性中MPLS Label字段值的设置为0。
实施中,所述IPv6源地址为128bit的字段;
网络前缀为BFIR节点网络标识,和/或,业务ID为L3VPN、L2VPN或EVPN的业务ID。
实施中,设置为BFIR的网络前缀以及业务ID的IPv6源地址是使用BGP属性来携带的。
一种组播报文传输方法,包括:
BFR接收IPv6 BIER报文,其中,所述IPv6 BIER报文中IPv6源地址设置为BFIR的网络前缀以及业务ID,IPv6目的地址设置为下一跳BFR的MPRA;
BFR根据网络前缀或业务ID、BFR的MPRA之一或者其组合对所述IPv6BIER报文进行处理。
实施中,在IPv6扩展报文头部位置通过在Destination Option Header增加一种类型Option来设置所述IPv6 BIER报文头部。
实施中,所述IPv6 BIER报文包括以下信息之一或者其组合:
BSL、SD、SI、RSV、TTL、Entropy、DSCP、Ver、OAM、BitString。
实施中,所述IPv6 BIER报文包括以下设置之一或者其组合:
用显式的BSL、SD以及SI替换BIFT-id字段;
显式BSL字段标识BitString长度;
原有BSL字段设置为保留字段;
TC设置为保留字段;
S flag设置为保留字段;
Nibble设置为保留字段;
Proto设置为保留字段;
BFIR-id设置为保留字段。
实施中,所述IPv6 BIER报文包括以下信息之一或者其组合:
BSL为BitString的长度;
SD为BIER子域标识;
SI为BIER集合标识;
TTL为BIER报文生命周期值;
Ver为协议版本号;
Entropy为用于支持ECMP路径选择;
OAM为用于BIER转发性能测量标识;
RSV为保留位,当前不用缺省为0;
DSCP为标识差分服务,通过编码值来区分优先级;
BitStirng为用来标识该BIER域出口节点的位集合。
实施中,进一步包括:
I-PMSI和S-PMSI AD路由的PTA属性中MPLS Label字段值的设置为0。
实施中,所述IPv6源地址为128bit的字段;
网络前缀为BFIR节点网络标识,和/或,业务ID为L3VPN、L2VPN或EVPN的业务ID。
实施中,设置为BFIR的网络前缀以及业务ID的IPv6源地址是使用BGP属性来携带的。
实施中,BFR根据网络前缀或业务ID、BFR的MPRA之一或者其组合对所述IPv6 BIER报文进行处理,包括以下处理之一或者其组合:
根据IPv6 BIER报文的BFR的MPRA查找单播路由表,在匹配本地组播策略保留地址成功后,解析IPv6-BIER报文;
根据BIER报头中的信息查找特定的BIFT表,判断本节点是否为BFER,如为BFER,解封装payload的内层组播报文,根据业务ID信息查找对应的组播路由表,进行相关的复制转发;如为普通BFR,则查找BIFT表进行BIER复制转发,其中,IPv6目的地址设置为下一跳的MPRA,IPv6源地址设置不变。
一种BFR,包括:
处理器,用于读取存储器中的程序,执行下列过程:
接收IP组播报文;
进行组播报文复制,进行IPv6 BIER报文封装并转发,其中,所述IPv6 BIER报文中IPv6源地址设置为BFIR的网络前缀以及业务ID,IPv6目的地址设置为下一跳BFR的MPRA;
收发机,用于在处理器的控制下接收和发送数据。
实施中,在IPv6扩展报文头部位置通过在Destination Option Header增加一种类型Option来设置所述IPv6 BIER报文头部。
实施中,所述IPv6 BIER报文包括以下信息之一或者其组合:
BSL、SD、SI、RSV、TTL、Entropy、DSCP、Ver、OAM、BitString。
实施中,所述IPv6 BIER报文包括以下设置之一或者其组合:
用显式的BSL、SD以及SI替换BIFT-id字段;
显式BSL字段标识BitString长度;
原有BSL字段设置为保留字段;
TC设置为保留字段;
S flag设置为保留字段;
Nibble设置为保留字段;
Proto设置为保留字段;
BFIR-id设置为保留字段。
实施中,所述IPv6 BIER报文包括以下信息之一或者其组合:
BSL为BitString的长度;
SD为BIER子域标识;
SI为BIER集合标识;
TTL为BIER报文生命周期值;
Ver为协议版本号;
Entropy为用于支持ECMP路径选择;
OAM为用于BIER转发性能测量标识;
RSV为保留位,当前不用缺省为0;
DSCP为标识差分服务,通过编码值来区分优先级;
BitStirng为用来标识该BIER域出口节点的位集合。
实施中,进一步包括:
I-PMSI和S-PMSI AD路由的PTA属性中MPLS Label字段值的设置为0。
实施中,所述IPv6源地址为128bit的字段;
网络前缀为BFIR节点网络标识,和/或,业务ID为L3VPN、L2VPN或EVPN的业务ID。
实施中,设置为BFIR的网络前缀以及业务ID的IPv6源地址是使用BGP属性来携带的。
一种BFR,包括:
第一接收模块,用于接收IP组播报文;
第一处理模块,用于进行组播报文复制,进行IPv6 BIER报文封装并转发,其中,所述IPv6 BIER报文中IPv6源地址设置为BFIR的网络前缀以及业务ID,IPv6目的地址设置为下一跳BFR的MPRA。
实施中,第一处理模块进一步用于在IPv6扩展报文头部位置通过在DestinationOption Header增加一种类型Option来设置所述IPv6 BIER报文头部。
实施中,第一处理模块进一步用于处理包括以下信息之一或者其组合的所述IPv6BIER报文:
BSL、SD、SI、RSV、TTL、Entropy、DSCP、Ver、OAM、BitString。
实施中,第一处理模块进一步用于处理包括以下设置之一或者其组合的所述IPv6BIER报文:
用显式的BSL、SD以及SI替换BIFT-id字段;
显式BSL字段标识BitString长度;
原有BSL字段设置为保留字段;
TC设置为保留字段;
S flag设置为保留字段;
Nibble设置为保留字段;
Proto设置为保留字段;
BFIR-id设置为保留字段。
实施中,所述IPv6 BIER报文包括以下信息之一或者其组合:
BSL为BitString的长度;
SD为BIER子域标识;
SI为BIER集合标识;
TTL为BIER报文生命周期值;
Ver为协议版本号;
Entropy为用于支持ECMP路径选择;
OAM为用于BIER转发性能测量标识;
RSV为保留位,当前不用缺省为0;
DSCP为标识差分服务,通过编码值来区分优先级;
BitStirng为用来标识该BIER域出口节点的位集合。
实施中,第一处理模块进一步用于将I-PMSI和S-PMSI AD路由的PTA属性中MPLSLabel字段值的设置为0。
实施中,所述IPv6源地址为128bit的字段;
网络前缀为BFIR节点网络标识,和/或,业务ID为L3VPN、L2VPN或EVPN的业务ID。
实施中,设置为BFIR的网络前缀以及业务ID的IPv6源地址是使用BGP属性来携带的。
一种BFR,包括:
处理器,用于读取存储器中的程序,执行下列过程:
接收IPv6 BIER报文,其中,所述IPv6 BIER报文中IPv6源地址设置为BFIR的网络前缀以及业务ID,IPv6目的地址设置为下一跳BFR的MPRA;
根据网络前缀或业务ID、BFR的MPRA之一或者其组合对所述IPv6 BIER报文进行处理;
收发机,用于在处理器的控制下接收和发送数据。
实施中,在IPv6扩展报文头部位置通过在Destination Option Header增加一种类型Option来设置所述IPv6 BIER报文头部。
实施中,所述IPv6 BIER报文包括以下信息之一或者其组合:
BSL、SD、SI、RSV、TTL、Entropy、DSCP、Ver、OAM、BitString。
实施中,所述IPv6 BIER报文包括以下设置之一或者其组合:
用显式的BSL、SD以及SI替换BIFT-id字段;
显式BSL字段标识BitString长度;
原有BSL字段设置为保留字段;
TC设置为保留字段;
S flag设置为保留字段;
Nibble设置为保留字段;
Proto设置为保留字段;
BFIR-id设置为保留字段。
实施中,所述IPv6 BIER报文包括以下信息之一或者其组合:
BSL为BitString的长度;
SD为BIER子域标识;
SI为BIER集合标识;
TTL为BIER报文生命周期值;
Ver为协议版本号;
Entropy为用于支持ECMP路径选择;
OAM为用于BIER转发性能测量标识;
RSV为保留位,当前不用缺省为0;
DSCP为标识差分服务,通过编码值来区分优先级;
BitStirng为用来标识该BIER域出口节点的位集合。
实施中,进一步包括:
I-PMSI和S-PMSI AD路由的PTA属性中MPLS Label字段值的设置为0。
实施中,所述IPv6源地址为128bit的字段;
网络前缀为BFIR节点网络标识,和/或,业务ID为L3VPN、L2VPN或EVPN的业务ID。
实施中,设置为BFIR的网络前缀以及业务ID的IPv6源地址是使用BGP属性来携带的。
实施中,BFR根据网络前缀或业务ID、BFR的MPRA之一或者其组合对所述IPv6 BIER报文进行处理,包括以下处理之一或者其组合:
根据IPv6 BIER报文的BFR的MPRA查找单播路由表,在匹配本地组播策略保留地址成功后,解析IPv6-BIER报文;
根据BIER报头中的信息查找特定的BIFT表,判断本节点是否为BFER,如为BFER,解封装payload的内层组播报文,根据业务ID信息查找对应的组播路由表,进行相关的复制转发;如为普通BFR,则查找BIFT表进行BIER复制转发,其中,IPv6目的地址设置为下一跳的MPRA,IPv6源地址设置不变。
一种BFR,包括:
第二接收模块,用于接收IPv6 BIER报文,其中,所述IPv6 BIER报文中IPv6源地址设置为BFIR的网络前缀以及业务ID,IPv6目的地址设置为下一跳BFR的MPRA;
第二处理模块,用于根据网络前缀或业务ID、BFR的MPRA之一或者其组合对所述IPv6 BIER报文进行处理。
实施中,第二接收模块进一步用于接收的所述IPv6 BIER报文头部是在IPv6扩展报文头部位置通过在Destination Option Header增加一种类型Option来设置的。
实施中,第二接收模块进一步用于接收包括以下信息之一或者其组合的所述IPv6BIER报文:
BSL、SD、SI、RSV、TTL、Entropy、DSCP、Ver、OAM、BitString。
实施中,第二接收模块进一步用于接收包括以下设置之一或者其组合的所述IPv6BIER报文:
用显式的BSL、SD以及SI替换BIFT-id字段;
显式BSL字段标识BitString长度;
原有BSL字段设置为保留字段;
TC设置为保留字段;
S flag设置为保留字段;
Nibble设置为保留字段;
Proto设置为保留字段;
BFIR-id设置为保留字段。
实施中,所述IPv6 BIER报文包括以下信息之一或者其组合:
BSL为BitString的长度;
SD为BIER子域标识;
SI为BIER集合标识;
TTL为BIER报文生命周期值;
Ver为协议版本号;
Entropy为用于支持ECMP路径选择;
OAM为用于BIER转发性能测量标识;
RSV为保留位,当前不用缺省为0;
DSCP为标识差分服务,通过编码值来区分优先级;
BitStirng为用来标识该BIER域出口节点的位集合。
实施中,I-PMSI和S-PMSI AD路由的PTA属性中MPLS Label字段值的设置为0。
实施中,所述IPv6源地址为128bit的字段;
网络前缀为BFIR节点网络标识,和/或,业务ID为L3VPN、L2VPN或EVPN的业务ID。
实施中,第二接收模块进一步用于接收使用BGP属性来携带的设置为BFIR的网络前缀以及业务ID的IPv6源地址。
实施中,第二处理模块进一步用于在根据网络前缀或业务ID、BFR的MPRA之一或者其组合对所述IPv6 BIER报文进行处理时,包括以下处理之一或者其组合:
根据IPv6 BIER报文的BFR的MPRA查找单播路由表,在匹配本地组播策略保留地址成功后,解析IPv6-BIER报文;
根据BIER报头中的信息查找特定的BIFT表,判断本节点是否为BFER,如为BFER,解封装payload的内层组播报文,根据业务ID信息查找对应的组播路由表,进行相关的复制转发;如为普通BFR,则查找BIFT表进行BIER复制转发,其中,IPv6目的地址设置为下一跳的MPRA,IPv6源地址设置不变。
一种计算机可读存储介质,所述计算机可读存储介质存储有执行上述组播报文传输方法的计算机程序。
本发明有益效果如下:
本发明实施例提供的技术方案中,所述IPv6 BIER报文中IPv6源地址设置为BFIR的网络前缀以及业务ID,IPv6目的地址设置为下一跳BFR的MPRA,由于IPv6源地址划分前缀部分和业务ID标识部分,组播应用实例(MVPN/EVPN等)分配业务ID标识,组播接收者设备可以根据IPv6源地址直接对应指定的组播应用实例。由于BIER封装简化并嵌入IPv6头部封装,形成基于IPv6的BIER转发模式。由于IPv6目的地址单独规划用于组播IPv6BIER转发预留,可在IPv6网络中插花部署BIER转发。
由于BFR节点接收到该报文时识别目的地址为本节点发布的MPRA,就可以查询IPv6 BIER头部进行组播转发,组播数据转发时由于因为源地址已经包含了业务ID,因此不再需要携带VPN标签,也因而避免了占用32bit报文头部空间。
进一步的,至少还有以下效果之一:
IPv6地址引入组播业务属性,扩展网络编程应用范围;
BIER封装与IPv6扩展有效结合,充分利用IPv6丰富扩展能力;
可以使IPv6网络平滑升级部署。
附图说明
此处所说明的附图用来提供对本发明的进一步理解,构成本发明的一部分,本发明的示意性实施例及其说明用于解释本发明,并不构成对本发明的不当限定。在附图中:
图1为本发明实施例中MPLS Label字段格式示意图;
图2为本发明实施例中BIER的封装格式示意图;
图3为本发明实施例中BFR作为BFIR时的组播报文传输方法实施流程示意图;
图4为本发明实施例中BFR的组播报文传输方法实施流程示意图;
图5为本发明实施例中BIER IPv6头部结构示意图;
图6为本发明实施例中IPv6 BIER报文格式示意图;
图7为本发明实施例中IPv6 BIER报文传输路径示意图;
图8为本发明实施例中BGP属性格式示意图;
图9为本发明实施例中MSI属性的一个sub-sub-TLV格式示意图;
图10为本发明实施例1的IPv6 BIER组播方案的实施示意图;
图11为本发明实施例2的IPv6 BIER组播方案的实施示意图;
图12为本发明实施例3的IPv6 BIER组播方案的实施示意图;
图13为本发明实施例中BFR结构一示意图;
图14为本发明实施例中BFR结构二示意图。
具体实施方式
发明人在发明过程中注意到:
传统的PIM(协议无关组播,Protocol Independent Multicast)协议需要逐跳加入建立组播树,但新型的BIER(位索引显式复制,Bit Index Explicit Replication)协议不需要用于显式构建多播分发树的协议,也不需要中间节点来维护任何组播流状态。当组播数据包进入BIER区域内,入口路由器会确定要将数据包发送到的出口路由器的集合。然后,入口路由器将数据包封装在BIER标头中。BIER报文头部包含一个位字符串,其中每个位表示域中的一个出口路由器;为了将数据包转发到给定的出口路由器集,在BIER报文头部设置了与出口路由器相对应的位。
BIER协议简化组播路由转发,无需组播控制协议运行,无需建立组播树和组播隧道,中间节点看不到任何组播流状态信息,也无需保存任何组播状态,只需要网络入口和出口设备上交互源和接收者信息。BIER节点仅根据网络拓扑进行转发,继承单播的FRR(快速重路由,Fast Reroute)和LFA(帧丢失,Loss of Frame Alignment)。BIER网络收敛速度跟单播一样快,无需组播状态的信令交互和收敛过程。
同时IPv6(互联网协议第6版,Internet Protocol Version 6)网络环境下组播承载使用IPv6报文封装,对于私网组播数据还需要对VPN(虚拟专用网络,Virtual PrivateNetwork)进行标识。从控制面来看,有方案定义PIM和P2MP(点对多点主站,point2multiple point)MPLS(多协议标签交换,MultiProtocol Label Switching)承载方式,有方案定义BIER承载方式,均要使用PTA(PMSI隧道属性,PMSI Tunnel Attribute;PMSI:公网组播服务接口,P-Multicast Service Interface)中的MPLS Label(标签)字段标识,图1为MPLS Label字段格式示意图,具体格式封装见图1所示,由Ingress PE(入口PE;PE:运营商边缘路由器,Provider Edge)通过BGP(边界网关协议,Border Gateway Protocol)MVPN(组播虚拟专用网,Multicast Virtual Private Network)X-PMSI(I-PMSI(包含PMSI,Inclusive-PMSI)/S-PMSI(选择PMSI,Selective-PMSI)统称)AD(自动发现,AutoDiscovery)路由通告各Egress PE(出口PE)。从数据面来看,组播数据报文通过IPv6封装,均需要使用VPN Label标识对应的MVPN。
图2为BIER的封装格式示意图,如图所示,根据现有方案公开的BIER的封装格式,BIER组播复制转发的核心信息是BIER头中的BIFT-id(BIFT标识,BIFT:位索引转发表,BitIndex Forwarding Table)和BitString(位串),BIFT-id确定BIER报文所在BIER子域和BFR(位转发路由器,Bit-Forwarding Router)子集,BitString中的bit(比特)位确定在该子域和子集中组播报文的BFER集合。BIER头部封装已经提供了QoS(服务质量,Quality ofService)、ECMP(等价多径,Equal-cost Multipath)、环路避免、OAM(操作管理维护,Operation Administration and Maintenance)、多业务承载等能力,Underlay(下层)层面主要解决BIER报文的传输。
目前,BIER Underlay层面主要封装模式有四种,分别是:BIER-MPLS、BIER-Ethernet(BIER-以太网)、BIERin6(draft-zhang-bier-bierin6-07)、BIERv6(draft-xie-bier-ipv6-encapsulation-08),针对IPv6网络不同封装模式尚未形成业界的统一意见,其中BIER-MPLS、BIER-Ethernet封装均不支持IPv6网络;BIERin6仅把BIER报文作为Payload(有效载荷)封装到IPv6,无法利用现有IPv6报文头的高扩展性;BIERv6在封装上BIER头部和IPv6头部部分字段存在冗余冲突。
IPv6网络承载组播流量,无论使用PIM、P2MP MPLS还是BIER,按照现有方案均需要从Ingress PE分配VPN标签,用于标识不同VPN,使得组播流量到达egress PE后可以进入对应的VPN查找IP组播表继续转发。组播数据转发时需要携带VPN标签,占用32bit报文头部空间。
基于此,本发明实施例中提供了组播报文传输方案,下面结合附图对本发明的具体实施方式进行说明。
具有BIER能力的路由器称之为BFR,即位转发路由器(Bit-Forwarding Router),BFR组成的域称之为BIER域,组播流量进入和离开BIER域的BFR分别称之为BFIR(位转发入口路由器,Bit-Forwarding ingress Router)和BFER(位转发出口路由器,Bit-Forwardingexit Router)。在说明过程中,将分别从BFIR与BFER侧的实施进行说明,然后还将给出多个BFR配合实施的实例以更好地理解本发明实施例中给出的方案的实施。这样的说明方式并不意味着它们必须配合实施、或者必须单独实施,实际上,当各BFR分开实施时,其也各自解决自身一侧的问题,而它们结合使用时,会获得更好的技术效果。
图3为BFR作为BFIR时的组播报文传输方法实施流程示意图,如图所示,包括:
步骤301、BFR接收IP组播报文;
步骤302、BFR进行组播报文复制,进行IPv6 BIER报文封装并转发,其中,所述IPv6BIER报文中IPv6源地址设置为BFIR的网络前缀以及业务ID,IPv6目的地址设置为下一跳BFR的MPRA。
图4为BFR的组播报文传输方法实施流程示意图,如图所示,包括:
步骤401、BFR接收IPv6 BIER报文,其中,所述IPv6 BIER报文中IPv6源地址设置为BFIR的网络前缀以及业务ID,IPv6目的地址设置为下一跳BFR的MPRA;
步骤402、BFR根据网络前缀或业务ID、BFR的MPRA之一或者其组合对所述IPv6BIER报文进行处理。
首先对IPv6 BIER报文的实施进行说明。
实施中,在IPv6扩展报文头部位置通过在Destination Option Header增加一种类型Option来设置所述IPv6 BIER报文头部。
图5为BIER IPv6头部结构示意图,如图所示,在本发明实施例给出的IPv6BIER组播方案中,BIER IPv6头部在IPv6扩展报文头部位置选择Destination Option Header(目的选项头部),新增一种类型Option,继承已有IPv6扩展头部定义的属性和顺序,仅改变扩展头部内部数据。
实施中,所述IPv6 BIER报文包括以下信息之一或者其组合:
BSL、SD、SI、RSV、TTL、Entropy、DSCP、Ver、OAM、BitString。
具体实施中,所述IPv6 BIER报文包括以下设置之一或者其组合:
用显式的BSL、SD以及SI替换BIFT-id字段;
显式BSL字段标识BitString长度;
原有BSL字段设置为保留字段;
TC设置为保留字段;
S flag设置为保留字段;
Nibble设置为保留字段;
Proto设置为保留字段;
BFIR-id设置为保留字段。
实施中,所述IPv6 BIER报文包括以下信息之一或者其组合:
BSL为BitString的长度;
SD为BIER子域标识;
SI为BIER集合标识;
TTL为BIER报文生命周期值;
Ver为协议版本号;
Entropy为用于支持ECMP路径选择;
OAM为用于BIER转发性能测量标识;
RSV为保留位,当前不用缺省为0;
DSCP为标识差分服务,通过编码值来区分优先级;
BitStirng为用来标识该BIER域出口节点的位集合。
具体的,图6为IPv6 BIER报文格式示意图,如图所示,基于IPv6的BIER头部格式不是完全继承现有报文section(章节、段落)2定义的BIER头部,而是基于IPv6头部已有格式定义进行调整,具体定义可以如下:
BSL:表示BitString的长度(log2(k)-5),既用作数据面转发时根据BSL、SD、SI字段确定BIER转发表,也用作数据面转发及离线报文分析时校验G-BIER头部及选项长度的正确性。
SD:子域(sub-domain),BIER域中的独立子域。
SI:集标识(Set Identifier),当使用的BSL长度不足以包括一个sub-domain所有节点的BFR-id时,需要分不同的集合,则不同集合使用不同的SI来标识。
BitStirng:位串,用来标识该BIER域出口节点的位集合,同SD、SI表示一组BFER路由器。
BIFT-id字段用显式的BSL/SD/SI替换,减少一次映射,显式BSL字段同时标识BitString长度,原有BSL字段不再使用设置为保留字段;其中,不同的Bitstring需要在不同的报文中转发,一个Bitstring对应于一个<SD,BSL,SI>,SD是BIER的sub-domain(子域),BSL是封装头的bitstringlength(位串长度),SI是子集标识(setidentifier),子域SD可以划分多个子集,并用SI标识。
TC(传输等级,Traffic Class)与IPv6头部的Traffic Class(传输等级)字段含义重复,不再使用设置为保留字段;
S flag(S标志)、Nibble(半字节)仅与MPLS转发相关,不再使用设置为保留字段;
Proto(协议)与扩展头部的Next Header(下一跳头部)含义重复,不再使用设置为保留字段;
BFIR-id与IPv6 Source address(源地址)含义重复,不再使用设置为保留字段;
TTL:同MPLS封装的TTL的使用,具体实施可以参见参考RFC3032。
Entropy:支持ECMP,相同的Entropy+BitString,选择相同的路径。
DSCP:Differentiated Service Codepoint,差分服务代码点,通过编码值来区分优先级。
TTL(存活时间,Time To Live)、Entropy(信息熵)、DSCP(区分服务码点,DiffServCode Point)虽然IPv6头部也有对应字段,但BIER头部定义中可仅应用于组播,继续使用。
Ver:表示版本号,当前值为0表示实验中的版本。
OAM:缺省为0,可用于Performance Measurement(PM)等OAM功能,不影响转发和QoS。
RSV(Reserved):保留位,当前不用缺省为0。RSV与Reserved都标识保留位,因为空间表示有限制所以在图中标识不同。
本发明实施例中的IPv6 BIER方案对IPv6源和目的地址做了定义如下:
IPv6目的地址作为IPv6 BIER下一跳的MPRA(组播策略保留地址,MulticastPolicy Reserved Address),采用单独规划的IP地址,与接口Loopback(环回)口地址段分开,便于安全策略配置部署。BIER转发路由器(BFR)上需要本地配置专门用于BIER转发的IPv6地址,并通过控制面消息发布本节点的该IPv6地址,以通知其它邻居在向本节点发送IPv6 BIER报文时使用该IPv6地址。IPv6 BIER报文转发时将下一跳BFR地址设置为对应该节点的MPRA,这样下一跳BFR节点接收到该报文时识别目的地址为本节点发布的MPRA,就可以查询IPv6 BIER头部进行组播转发。
实施中,所述IPv6源地址为128bit的字段;
网络前缀为BFIR节点网络标识,和/或,业务ID为L3VPN、L2VPN或EVPN的业务ID。
实施中,进一步包括:
I-PMSI和S-PMSI AD路由的PTA属性中MPLS Label字段值的设置为0。
具体的,IPv6源地址引入网络编程思想,把128bit的地址分为前缀和业务标识两个部分,前缀部分作为BFIR节点网络标识、业务标识部分作为L3VPN(3层VPN)、L2VPN(2层VPN)、EVPN(以太网VPN,Ethernet VPN)等业务ID。IPv6 BIER报文转发不再使用单独的VPNLabel字段,而是使用IPv6源地址来标识MVPN实例。从控制消息上看,通过使用新的BGP属性通告相应的BFIR前缀和业务ID,前述X-PMSI AD路由的PTA属性中MPLS Label字段值则可以设置为0。
图7为IPv6 BIER报文传输路径示意图,如图所示,用于MVPN或EVPN的L3组播时,出口PE节点由于需要支持根据选定的UMH(上游组播跳,Upstream Multicast Hop)进行组播RPF(逆向路径转发,Reverse path forwarding)检查,因此不仅需要知道IPv6 BIER报文属于哪个MVPN实例,还需要知道报文来自于哪个入口PE,一个IPv6源地址可以同时包含这两部分信息,具体的说,报文来自于哪个入口PE是IPv6源地址的前缀部分,报文属于哪个MVPN实例则是IPv6源地址的业务ID部分,但这个业务ID要以特定的节点作为上下文。
使用IPv6源地址来标识MVPN实例,可以进一步推广到标识EVPN实例、用于EVPN组播或者EVPN同网段的BUM(广播、未知单播、组播,broadcast&unknown-unicast&multicast)广播。在用于EVPN同网段的BUM广播时,租户的各NVE(网络虚拟边缘节点,NetworkVirtrualization Edge)节点只需要知道收到的报文属于哪个Intra-subnet(子网内)的EVI(以太虚拟专用网实例,EVPN instance)(或Intra-subnet的租户,或Bridge-domain(桥域)),而不需要RPF检查,即不需要知道报文来自于哪个入口PE。这种情况下,只需要根据IPv6源地址中的ID部分确定报文的VNI(虚拟的网络标识,Virtual Network Identifier)、再根据本地配置确定该VNI(或该报文)属于哪个Bridge-domain。
这种使用IPv6源地址前缀和业务ID用于组播转发的方案,可以使用一个新的BGP属性来携带,该BGP属性作为参考可称为“Multicast Service Identifier(组播业务标识符)”属性或简称MSI属性。也即,实施中,设置为BFIR的网络前缀以及业务ID的IPv6源地址是使用BGP属性来携带的。
图8为BGP属性格式示意图,该新增属性定义格式可参考图8所示。
图9为MSI属性的一个sub-sub-TLV格式示意图,其中用于定义IPv6源地址字段划分的格式定义可作为BGP新定义MSI属性的一个sub-sub-TLV(子-子-TLV;TLV:类型、长度、值,Tag、Length、Value)可参考图9所示。
根据以上的IPv6 BIER格式定义,IPv6 BIER的基本转发过程可以如下:
作为入口PE的BFIR:
根据Overlay层提供的IP组播表项及对应的SD、SI、BSL和BitString信息,进行组播报文复制,查找BIFT表(BIER forwarding表),进行IPv6 BIER报文封装并转发。其中,IPv6源地址(SA)设置为BFIR的网络前缀+业务ID,IPv6目的地址(DA)设置为下一跳BFR的MPRA。
中间节点:
实施中,BFR根据网络前缀或业务ID、BFR的MPRA之一或者其组合对所述IPv6 BIER报文进行处理,包括以下处理之一或者其组合:
根据IPv6 BIER报文的BFR的MPRA查找单播路由表,在匹配本地组播策略保留地址成功后,解析IPv6-BIER报文;
根据BIER报头中的信息查找特定的BIFT表,判断本节点是否为BFER,如为BFER,解封装payload的内层组播报文,根据业务ID信息查找对应的组播路由表,进行相关的复制转发;如为普通BFR,则查找BIFT表进行BIER复制转发,其中,IPv6目的地址设置为下一跳的MPRA,IPv6源地址设置不变。
具体的,根据IPv6 BIER报文DA查找单播路由表,匹配本地组播策略保留地址,如匹配成功,需解析IPv6 BIER报文。根据BIER报头中的SD、SI、BSL查找特定的BIERforwarding表(BIFT),比对BitString信息及本地BFR-ID,判断本节点是否为BFER。如为BFER,解封装payload的内层组播报文,根据SA中的MS ID(组播业务标识)信息查找对应的组播路由表,进行相关的复制转发。如果为普通BFR,则根据BitString信息继续查找BIFT表进行BIER复制转发,其中DA设置为下一跳的组播策略保留地址,SA保持不变。
根据以上转发过程,下面以实例来对IPv6 BIER组播方案的实施进行说明。
首先,设各设备IPv6 BIER相关配置如下:
PSR(省业务路由器,Province Service Router)1台;PE 2台;MB(城域主干网,Metro Backbone)2台;SR(业务路由器,Service Router)3台。PSR-PE-MB-SR节点的标识分别是A:1,B:1/B:2,C:1/C:2,D:1/D:2/D:3;
PSR-PE-MB-SR节点的MPRA分别是A:1::FFFE,B:1::FFFE/B:2::FFFE,C:1::FFFE/C:2::FFFE,D:1::FFFE/D:2::FFFE/D:3::FFFE;
PSR上使用A:1:6:/112的地址标识BFIR前缀,低16bit的1000标识MVPN ID。
实施例1:
本场景下网络全部设备支持IPv6 BIER组播方案。
图10为实施例1的IPv6 BIER组播方案的实施示意图,如图所示,可以如下:
1.PSR1 MVPN实例私网侧从CE(用户边缘路由器,Customer Edge)(未画出)收到IP组播报文,找到接收到组播报文的接口关联的MVPN转发实例,在MVPN转发实例中查找IP组播转发表,确定组播报文在IPv6 BIER类型的PMSI隧道上转发,以及IPv6 BIER PMSI隧道对应的IPv6 SA、BSL/SD/SI、BitString等参数,并按BSL/SD/SI和BitString查找本地IPv6BIER转发表,确定向IPv6 BIER邻居PE1转发,转发封装SA=A:1:6::1000,DA=B:1::FFFE(邻居PE1的MPRA)、BSL/SD/SI=3/0/0(其中BSL=3表示256bits)、BitString=0111,根据DA进行IPv6单播转发。
2.PE1节点收到报文,报文的IPv6 DA命中MPRA B:1::FFFE,按报文的BSL/SD/SI和BitString查找本地IPv6 BIER转发表,确定向邻居MB1转发,转发封装SA不变,DA=C:1::FFFE(邻居MB1的MPRA)、BSL/SD/SI=3/0/0、BitString=0111。
3.MB1节点收到报文,报文的IPv6 DA命中MPRA C:1::FFFE,按报文的BSL/SD/SI和BitString查找本地IPv6 BIER转发表,确定向邻居SR1/SR2/SR3复制转发,以SR1为例,转发封装SA不变,DA=D:1::FFFE(邻居SR1的MPRA)、BSL/SD/SI=3/0/0、BitString=0001。向SR2/SR3转发的报文封装类似,不再赘述(图中给出向SR3转发的报文格式)。
4.SR1节点收到报文,报文的IPv6 DA命中MRPA D:1::FFFE,并且Bit String 0001中置位1的bit对应的BFR-id是SR1自己的BFR-id。IPv6 BIER解封装,同时校验IPv6 SA前缀部分的BFIR是否通过RPF检查,查找MVPN ID对应的本地MVPN实例,报文payload进入对应的MVPN转发实例进行私网IP组播转发。SR2/SR3节点的报文处理过程类似,不再赘述。
实施例2:
本场景中,非分支节点不支持IPv6 BIER组播方案。
图11为实施例2的IPv6 BIER组播方案的实施示意图,如图所示,可以如下:
1.PSR1 MVPN实例私网侧从CE(未画出)收到IP组播报文,找到接收到组播报文的接口关联的MVPN转发实例,在MVPN转发实例中查找IP组播转发表,确定组播报文在IPv6BIER类型的PMSI隧道上转发,以及IPv6 BIER PMSI隧道对应的IPv6 SA、BSL/SD/SI、BitString等参数,并按BSL/SD/SI和BitString查找本地IPv6 BIER转发表,由于单播路由的下一跳PE1为Non-BFR即不支持IPv6 BIER的节点,因此确定直接向IPv6 BIER邻居即下一跳BFR MB1转发,转发封装SA=A:1:6::1000,DA=C:1::FFFE(非直连邻居MB1的MPRA)、BSL/SD/SI=3/0/0(其中BSL=3表示256bits)、BitString=0111,根据DA进行IPv6单播转发。
2.MB1/SR1/SR2/SR3节点的报文转发和处理过程与实施例1场景相同。
实施例3:
本场景中,分支节点不支持IPv6 BIER组播方案。
图12为实施例3的IPv6 BIER组播方案的实施示意图,如图所示,可以如下:
1.PSR1节点的报文封装和转发过程与第一种场景相同.
2.PE1节点收到报文,报文的IPv6 DA命中MPRA B:1::FFFE,按报文的BSL/SD/SI和BitString查找本地IPv6 BIER转发表,由于单播路由的下一跳MB1为Non-BFR即不支持IPv6BIER的节点,因此确定直接向IPv6 BIER邻居即下一跳BFR SR1/SR2/SR3进行复制并转发,以SR1为例,转发封装SA不变,DA=D:1::FFFE(邻居SR1的MPRA)、BSL/SD/SI=3/0/0、BitString=0001。向SR2/SR3转发的报文封装类似,不再赘述。
这种场景由于MB1为分支点不支持IPv6 BIER组播复制,造成实际组播流量从PE1就进行复制并分别向SR1/SR2/SR3转发,使得PE1-MB1路径组播流量出现冗余。
3.SR1/SR2/SR3节点的报文转发和处理过程与实施例1场景相同。
基于同一发明构思,本发明实施例中还提供了一种BFR、及计算机可读存储介质,由于这些设备解决问题的原理与组播报文传输方法相似,因此这些设备的实施可以参见方法的实施,重复之处不再赘述。
在实施本发明实施例提供的技术方案时,可以按如下方式实施。
图13为BFR结构一示意图,如图所示,BFR中包括:
处理器1300,用于读取存储器1320中的程序,执行下列过程:
接收IP组播报文;
进行组播报文复制,进行IPv6 BIER报文封装并转发,其中,所述IPv6 BIER报文中IPv6源地址设置为BFIR的网络前缀以及业务ID,IPv6目的地址设置为下一跳BFR的MPRA;
收发机1310,用于在处理器1300的控制下接收和发送数据。
实施中,在IPv6扩展报文头部位置通过在Destination Option Header增加一种类型Option来设置所述IPv6 BIER报文头部。
实施中,所述IPv6 BIER报文包括以下信息之一或者其组合:
BSL、SD、SI、RSV、TTL、Entropy、DSCP、Ver、OAM、BitString。
实施中,所述IPv6 BIER报文包括以下设置之一或者其组合:
用显式的BSL、SD以及SI替换BIFT-id字段;
显式BSL字段标识BitString长度;
原有BSL字段设置为保留字段;
TC设置为保留字段;
S flag设置为保留字段;
Nibble设置为保留字段;
Proto设置为保留字段;
BFIR-id设置为保留字段。
实施中,所述IPv6 BIER报文包括以下信息之一或者其组合:
BSL为BitString的长度;
SD为BIER子域标识;
SI为BIER集合标识;
TTL为BIER报文生命周期值;
Ver为协议版本号;
Entropy为用于支持ECMP路径选择;
OAM为用于BIER转发性能测量标识;
RSV为保留位,当前不用缺省为0;
DSCP为标识差分服务,通过编码值来区分优先级;
BitStirng为用来标识该BIER域出口节点的位集合。
实施中,进一步包括:
I-PMSI和S-PMSI AD路由的PTA属性中MPLS Label字段值的设置为0。
实施中,所述IPv6源地址为128bit的字段;
网络前缀为BFIR节点网络标识,和/或,业务ID为L3VPN、L2VPN或EVPN的业务ID。
实施中,设置为BFIR的网络前缀以及业务ID的IPv6源地址是使用BGP属性来携带的。
其中,在图13中,总线架构可以包括任意数量的互联的总线和桥,具体由处理器1300代表的一个或多个处理器和存储器1320代表的存储器的各种电路链接在一起。总线架构还可以将诸如外围设备、稳压器和功率管理电路等之类的各种其他电路链接在一起,这些都是本领域所公知的,因此,本文不再对其进行进一步描述。总线接口提供接口。收发机1310可以是多个元件,即包括发送机和接收机,提供用于在传输介质上与各种其他装置通信的单元。处理器1300负责管理总线架构和通常的处理,存储器1320可以存储处理器1300在执行操作时所使用的数据。
本发明实施例中还提供了一种BFR,包括:
第一接收模块,用于接收IP组播报文;
第一处理模块,用于进行组播报文复制,进行IPv6 BIER报文封装并转发,其中,所述IPv6 BIER报文中IPv6源地址设置为BFIR的网络前缀以及业务ID,IPv6目的地址设置为下一跳BFR的MPRA。
实施中,第一处理模块进一步用于在IPv6扩展报文头部位置通过在DestinationOption Header增加一种类型Option来设置所述IPv6 BIER报文头部。
实施中,第一处理模块进一步用于处理包括以下信息之一或者其组合的所述IPv6BIER报文:
BSL、SD、SI、RSV、TTL、Entropy、DSCP、Ver、OAM、BitString。
实施中,第一处理模块进一步用于处理包括以下设置之一或者其组合的所述IPv6BIER报文:
用显式的BSL、SD以及SI替换BIFT-id字段;
显式BSL字段标识BitString长度;
原有BSL字段设置为保留字段;
TC设置为保留字段;
S flag设置为保留字段;
Nibble设置为保留字段;
Proto设置为保留字段;
BFIR-id设置为保留字段。
实施中,所述IPv6 BIER报文包括以下信息之一或者其组合:
BSL为BitString的长度;
SD为BIER子域标识;
SI为BIER集合标识;
TTL为BIER报文生命周期值;
Ver为协议版本号;
Entropy为用于支持ECMP路径选择;
OAM为用于BIER转发性能测量标识;
RSV为保留位,当前不用缺省为0;
DSCP为标识差分服务,通过编码值来区分优先级;
BitStirng为用来标识该BIER域出口节点的位集合。
实施中,第一处理模块进一步用于将I-PMSI和S-PMSI AD路由的PTA属性中MPLSLabel字段值的设置为0。
实施中,所述IPv6源地址为128bit的字段;
网络前缀为BFIR节点网络标识,和/或,业务ID为L3VPN、L2VPN或EVPN的业务ID。
实施中,设置为BFIR的网络前缀以及业务ID的IPv6源地址是使用BGP属性来携带的。
为了描述的方便,以上所述装置的各部分以功能分为各种模块或单元分别描述。当然,在实施本发明时可以把各模块或单元的功能在同一个或多个软件或硬件中实现。
图14为BFR结构二示意图,如图所示,BFR中包括:
处理器1400,用于读取存储器1420中的程序,执行下列过程:
接收IPv6 BIER报文,其中,所述IPv6 BIER报文中IPv6源地址设置为BFIR的网络前缀以及业务ID,IPv6目的地址设置为下一跳BFR的MPRA;
根据网络前缀或业务ID、BFR的MPRA之一或者其组合对所述IPv6 BIER报文进行处理;
收发机1410,用于在处理器1400的控制下接收和发送数据。
实施中,在IPv6扩展报文头部位置通过在Destination Option Header增加一种类型Option来设置所述IPv6 BIER报文头部。
实施中,所述IPv6 BIER报文包括以下信息之一或者其组合:
BSL、SD、SI、RSV、TTL、Entropy、DSCP、Ver、OAM、BitString。
实施中,所述IPv6 BIER报文包括以下设置之一或者其组合:
用显式的BSL、SD以及SI替换BIFT-id字段;
显式BSL字段标识BitString长度;
原有BSL字段设置为保留字段;
TC设置为保留字段;
S flag设置为保留字段;
Nibble设置为保留字段;
Proto设置为保留字段;
BFIR-id设置为保留字段。
实施中,所述IPv6 BIER报文包括以下信息之一或者其组合:
BSL为BitString的长度;
SD为BIER子域标识;
SI为BIER集合标识;
TTL为BIER报文生命周期值;
Ver为协议版本号;
Entropy为用于支持ECMP路径选择;
OAM为用于BIER转发性能测量标识;
RSV为保留位,当前不用缺省为0;
DSCP为标识差分服务,通过编码值来区分优先级;
BitStirng为用来标识该BIER域出口节点的位集合。
实施中,进一步包括:
I-PMSI和S-PMSI AD路由的PTA属性中MPLS Label字段值的设置为0。
实施中,所述IPv6源地址为128bit的字段;
网络前缀为BFIR节点网络标识,和/或,业务ID为L3VPN、L2VPN或EVPN的业务ID。
实施中,设置为BFIR的网络前缀以及业务ID的IPv6源地址是使用BGP属性来携带的。
实施中,BFR根据网络前缀或业务ID、BFR的MPRA之一或者其组合对所述IPv6 BIER报文进行处理,包括以下处理之一或者其组合:
根据IPv6 BIER报文的BFR的MPRA查找单播路由表,在匹配本地组播策略保留地址成功后,解析IPv6-BIER报文;
根据BIER报头中的信息查找特定的BIFT表,判断本节点是否为BFER,如为BFER,解封装payload的内层组播报文,根据业务ID信息查找对应的组播路由表,进行相关的复制转发;如为普通BFR,则查找BIFT表进行BIER复制转发,其中,IPv6目的地址设置为下一跳的MPRA,IPv6源地址设置不变。
其中,在图14中,总线架构可以包括任意数量的互联的总线和桥,具体由处理器1400代表的一个或多个处理器和存储器1420代表的存储器的各种电路链接在一起。总线架构还可以将诸如外围设备、稳压器和功率管理电路等之类的各种其他电路链接在一起,这些都是本领域所公知的,因此,本文不再对其进行进一步描述。总线接口提供接口。收发机1410可以是多个元件,即包括发送机和接收机,提供用于在传输介质上与各种其他装置通信的单元。处理器1400负责管理总线架构和通常的处理,存储器1420可以存储处理器1400在执行操作时所使用的数据。
本发明实施例中还提供了一种BFR,包括:
第二接收模块,用于接收IPv6 BIER报文,其中,所述IPv6 BIER报文中IPv6源地址设置为BFIR的网络前缀以及业务ID,IPv6目的地址设置为下一跳BFR的MPRA;
第二处理模块,用于根据网络前缀或业务ID、BFR的MPRA之一或者其组合对所述IPv6 BIER报文进行处理。
实施中,第二接收模块进一步用于接收的所述IPv6 BIER报文头部是在IPv6扩展报文头部位置通过在Destination Option Header增加一种类型Option来设置的。
实施中,第二接收模块进一步用于接收包括以下信息之一或者其组合的所述IPv6BIER报文:
BSL、SD、SI、RSV、TTL、Entropy、DSCP、Ver、OAM、BitString。
实施中,第二接收模块进一步用于接收包括以下设置之一或者其组合的所述IPv6BIER报文:
用显式的BSL、SD以及SI替换BIFT-id字段;
显式BSL字段标识BitString长度;
原有BSL字段设置为保留字段;
TC设置为保留字段;
S flag设置为保留字段;
Nibble设置为保留字段;
Proto设置为保留字段;
BFIR-id设置为保留字段。
实施中,所述IPv6 BIER报文包括以下信息之一或者其组合:
BSL为BitString的长度;
SD为BIER子域标识;
SI为BIER集合标识;
TTL为BIER报文生命周期值;
Ver为协议版本号;
Entropy为用于支持ECMP路径选择;
OAM为用于BIER转发性能测量标识;
RSV为保留位,当前不用缺省为0;
DSCP为标识差分服务,通过编码值来区分优先级;
BitStirng为用来标识该BIER域出口节点的位集合。
实施中,I-PMSI和S-PMSI AD路由的PTA属性中MPLS Label字段值的设置为0。
实施中,所述IPv6源地址为128bit的字段;
网络前缀为BFIR节点网络标识,和/或,业务ID为L3VPN、L2VPN或EVPN的业务ID。
实施中,第二接收模块进一步用于接收使用BGP属性来携带的设置为BFIR的网络前缀以及业务ID的IPv6源地址。
实施中,第二处理模块进一步用于在根据网络前缀或业务ID、BFR的MPRA之一或者其组合对所述IPv6 BIER报文进行处理时,包括以下处理之一或者其组合:
根据IPv6 BIER报文的BFR的MPRA查找单播路由表,在匹配本地组播策略保留地址成功后,解析IPv6-BIER报文;
根据BIER报头中的信息查找特定的BIFT表,判断本节点是否为BFER,如为BFER,解封装payload的内层组播报文,根据业务ID信息查找对应的组播路由表,进行相关的复制转发;如为普通BFR,则查找BIFT表进行BIER复制转发,其中,IPv6目的地址设置为下一跳的MPRA,IPv6源地址设置不变。
为了描述的方便,以上所述装置的各部分以功能分为各种模块或单元分别描述。当然,在实施本发明时可以把各模块或单元的功能在同一个或多个软件或硬件中实现。
本发明实施例中还提供了一种计算机可读存储介质,所述计算机可读存储介质存储有执行上述组播报文传输方法的计算机程序。
具体实施可以参见组播报文传输方法的实施。
综上所述,本发明实施例提供的技术方案中,IPv6源地址划分前缀部分和业务ID标识部分,组播应用实例(MVPN/EVPN等)分配业务ID标识,组播接收者设备根据IPv6源地址直接对应指定的组播应用实例。
BIER封装简化并嵌入IPv6头部封装,形成基于IPv6的BIER转发模式。
IPv6目的地址单独规划用于组播IPv6 BIER转发预留,可在IPv6网络中插花部署BIER转发。
可见,IPv6地址引入组播业务属性,扩展网络编程应用范围;
BIER封装与IPv6扩展有效结合,充分利用IPv6丰富扩展能力;
可以使IPv6网络平滑升级部署。
本领域内的技术人员应明白,本发明的实施例可提供为方法、系统、或计算机程序产品。因此,本发明可采用完全硬件实施例、完全软件实施例、或结合软件和硬件方面的实施例的形式。而且,本发明可采用在一个或多个其中包含有计算机可用程序代码的计算机可用存储介质(包括但不限于磁盘存储器和光学存储器等)上实施的计算机程序产品的形式。
本发明是参照根据本发明实施例的方法、设备(系统)、和计算机程序产品的流程图和/或方框图来描述的。应理解可由计算机程序指令实现流程图和/或方框图中的每一流程和/或方框、以及流程图和/或方框图中的流程和/或方框的结合。可提供这些计算机程序指令到通用计算机、专用计算机、嵌入式处理机或其他可编程数据处理设备的处理器以产生一个机器,使得通过计算机或其他可编程数据处理设备的处理器执行的指令产生用于实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能的装置。
这些计算机程序指令也可存储在能引导计算机或其他可编程数据处理设备以特定方式工作的计算机可读存储器中,使得存储在该计算机可读存储器中的指令产生包括指令装置的制造品,该指令装置实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能。
这些计算机程序指令也可装载到计算机或其他可编程数据处理设备上,使得在计算机或其他可编程设备上执行一系列操作步骤以产生计算机实现的处理,从而在计算机或其他可编程设备上执行的指令提供用于实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能的步骤。
显然,本领域的技术人员可以对本发明进行各种改动和变型而不脱离本发明的精神和范围。这样,倘若本发明的这些修改和变型属于本发明权利要求及其等同技术的范围之内,则本发明也意图包含这些改动和变型在内。
Claims (22)
1.一种组播报文传输方法,其特征在于,包括:
位转发路由器BFR接收IP组播报文;
BFR进行组播报文复制,进行IPv6位索引显式复制BIER报文封装并转发,其中,所述IPv6 BIER报文中IPv6源地址设置为BFIR的网络前缀以及业务ID,IPv6目的地址设置为下一跳BFR的组播策略保留地址MPRA。
2.如权利要求1所述的方法,其特征在于,在IPv6扩展报文头部位置通过在目的选项头部Destination Option Header增加一种类型选项Option来设置所述IPv6 BIER报文头部。
3.如权利要求1所述的方法,其特征在于,所述IPv6 BIER报文包括以下信息之一或者其组合:
显式的位串长度BSL、子域SD、子集标识SI、保留位RSV、存活时间TTL、信息熵Entropy、区分服务码点DSCP、版本号Ver、OAM、位串BitString。
4.如权利要求3所述的方法,其特征在于,所述IPv6 BIER报文包括以下设置之一或者其组合:
用显式的BSL、SD以及SI替换BIFT-id字段;
显式BSL字段标识BitString长度;
原有BSL字段设置为保留字段;
TC设置为保留字段;
S flag设置为保留字段;
Nibble设置为保留字段;
Proto设置为保留字段;
BFIR-id设置为保留字段。
5.如权利要求1所述的方法,其特征在于,所述IPv6 BIER报文包括以下信息之一或者其组合:
BSL为BitString的长度;
SD为BIER子域标识;
SI为BIER集合标识;
TTL为BIER报文生命周期值;
Ver为协议版本号;
Entropy为用于支持ECMP路径选择;
OAM为用于BIER转发性能测量标识;
RSV为保留位,当前不用缺省为0;
DSCP为标识差分服务,通过编码值来区分优先级;
BitStirng为用来标识该BIER域出口节点的位集合。
6.如权利要求1所述的方法,其特征在于,进一步包括:
包含-公网组播服务接口I-PMSI和选择-公网组播服务接口S-PMSI自动发现AD路由的PMSI隧道属性PTA属性中多协议标签交换标签MPLS Label字段值的设置为0。
7.如权利要求1所述的方法,其特征在于,所述IPv6源地址为128bit的字段;
网络前缀为BFIR节点网络标识,和/或,业务ID为3层虚拟专用网络L3VPN、2层虚拟专用网络L2VPN或以太网虚拟专用网络EVPN的业务标识ID。
8.如权利要求1所述的方法,其特征在于,设置为BFIR的网络前缀以及业务ID的IPv6源地址是使用边界网关协议BGP属性来携带的。
9.一种组播报文传输方法,其特征在于,包括:
BFR接收IPv6 BIER报文,其中,所述IPv6 BIER报文中IPv6源地址设置为BFIR的网络前缀以及业务ID,IPv6目的地址设置为下一跳BFR的MPRA;
BFR根据网络前缀或业务ID、BFR的MPRA之一或者其组合对所述IPv6BIER报文进行处理。
10.如权利要求9所述的方法,其特征在于,在IPv6扩展报文头部位置通过在Destination Option Header增加一种类型Option来设置所述IPv6 BIER报文头部。
11.如权利要求9所述的方法,其特征在于,所述IPv6 BIER报文包括以下信息之一或者其组合:
BSL、SD、SI、RSV、TTL、Entropy、DSCP、Ver、OAM、BitString。
12.如权利要求11所述的方法,其特征在于,所述IPv6 BIER报文包括以下设置之一或者其组合:
用显式的BSL、SD以及SI替换BIFT-id字段;
显式BSL字段标识BitString长度;
原有BSL字段设置为保留字段;
TC设置为保留字段;
S flag设置为保留字段;
Nibble设置为保留字段;
Proto设置为保留字段;
BFIR-id设置为保留字段。
13.如权利要求9所述的方法,其特征在于,所述IPv6 BIER报文包括以下信息之一或者其组合:
BSL为BitString的长度;
SD为BIER子域标识;
SI为BIER集合标识;
TTL为BIER报文生命周期值;
Ver为协议版本号;
Entropy为用于支持ECMP路径选择;
OAM为用于BIER转发性能测量标识;
RSV为保留位,当前不用缺省为0;
DSCP为标识差分服务,通过编码值来区分优先级;
BitStirng为用来标识该BIER域出口节点的位集合。
14.如权利要求9所述的方法,其特征在于,进一步包括:
I-PMSI和S-PMSIAD路由的PTA属性中MPLS Label字段值的设置为0。
15.如权利要求9所述的方法,其特征在于,所述IPv6源地址为128bit的字段;
网络前缀为BFIR节点网络标识,和/或,业务ID为L3VPN、L2VPN或EVPN的业务ID。
16.如权利要求9所述的方法,其特征在于,设置为BFIR的网络前缀以及业务ID的IPv6源地址是使用BGP属性来携带的。
17.如权利要求9至16任一所述的方法,其特征在于,BFR根据网络前缀或业务ID、BFR的MPRA之一或者其组合对所述IPv6 BIER报文进行处理,包括以下处理之一或者其组合:
根据IPv6 BIER报文的BFR的MPRA查找单播路由表,在匹配本地组播策略保留地址成功后,解析IPv6-BIER报文;
根据BIER报头中的信息查找特定的BIFT表,判断本节点是否为BFER,如为BFER,解封装payload的内层组播报文,根据业务ID信息查找对应的组播路由表,进行相关的复制转发;如为普通BFR,则查找BIFT表进行BIER复制转发,其中,IPv6目的地址设置为下一跳的MPRA,IPv6源地址设置不变。
18.一种BFR,其特征在于,包括:
处理器,用于读取存储器中的程序,执行下列过程:
接收IP组播报文;
进行组播报文复制,进行IPv6 BIER报文封装并转发,其中,所述IPv6 BIER报文中IPv6源地址设置为BFIR的网络前缀以及业务ID,IPv6目的地址设置为下一跳BFR的MPRA;
收发机,用于在处理器的控制下接收和发送数据。
19.一种BFR,其特征在于,包括:
第一接收模块,用于接收IP组播报文;
第一处理模块,用于进行组播报文复制,进行IPv6 BIER报文封装并转发,其中,所述IPv6 BIER报文中IPv6源地址设置为BFIR的网络前缀以及业务ID,IPv6目的地址设置为下一跳BFR的MPRA。
20.一种BFR,其特征在于,包括:
处理器,用于读取存储器中的程序,执行下列过程:
接收IPv6 BIER报文,其中,所述IPv6 BIER报文中IPv6源地址设置为BFIR的网络前缀以及业务ID,IPv6目的地址设置为下一跳BFR的MPRA;
根据网络前缀或业务ID、BFR的MPRA之一或者其组合对所述IPv6 BIER报文进行处理;
收发机,用于在处理器的控制下接收和发送数据。
21.一种BFR,其特征在于,包括:
第二接收模块,用于接收IPv6 BIER报文,其中,所述IPv6 BIER报文中IPv6源地址设置为BFIR的网络前缀以及业务ID,IPv6目的地址设置为下一跳BFR的MPRA;
第二处理模块,用于根据网络前缀或业务ID、BFR的MPRA之一或者其组合对所述IPv6BIER报文进行处理。
22.一种计算机可读存储介质,其特征在于,所述计算机可读存储介质存储有执行权利要求1至17任一所述方法的计算机程序。
Priority Applications (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202110168399.4A CN114945000B (zh) | 2021-02-07 | 2021-02-07 | 一种组播报文传输方法、位转发路由器及存储介质 |
PCT/CN2022/074403 WO2022166773A1 (zh) | 2021-02-07 | 2022-01-27 | 一种组播报文传输方法、位转发路由器及存储介质 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202110168399.4A CN114945000B (zh) | 2021-02-07 | 2021-02-07 | 一种组播报文传输方法、位转发路由器及存储介质 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN114945000A true CN114945000A (zh) | 2022-08-26 |
CN114945000B CN114945000B (zh) | 2023-08-15 |
Family
ID=82741946
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202110168399.4A Active CN114945000B (zh) | 2021-02-07 | 2021-02-07 | 一种组播报文传输方法、位转发路由器及存储介质 |
Country Status (2)
Country | Link |
---|---|
CN (1) | CN114945000B (zh) |
WO (1) | WO2022166773A1 (zh) |
Cited By (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
WO2024061184A1 (zh) * | 2022-09-22 | 2024-03-28 | 华为技术有限公司 | 对应关系的获取方法、参数通告方法、装置、设备及介质 |
WO2024067339A1 (zh) * | 2022-09-29 | 2024-04-04 | 中兴通讯股份有限公司 | 组播流量报文转发方法及系统、计算机设备及可读介质 |
Families Citing this family (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN115333882B (zh) * | 2022-08-12 | 2024-06-07 | 中国电信股份有限公司 | 一种信息处理方法及相关设备 |
Citations (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN104811387A (zh) * | 2014-01-24 | 2015-07-29 | 思科技术公司 | 具有位索引显式复制的等价多路径 |
US20190020583A1 (en) * | 2017-07-11 | 2019-01-17 | Cisco Technology, Inc. | Forwarding of Packets in a Network Based on Multiple Compact Forwarding Identifiers Represented in a Single Internet Protocol Version 6 (IPv6) Address |
CN109246017A (zh) * | 2018-11-28 | 2019-01-18 | 新华三技术有限公司 | 一种查询组播转发路径的方法及装置 |
CN111669330A (zh) * | 2019-03-08 | 2020-09-15 | 华为技术有限公司 | 一种bier报文的发送方法和装置 |
Family Cites Families (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN109150730A (zh) * | 2017-06-15 | 2019-01-04 | 中兴通讯股份有限公司 | 组播跨域方法、装置、系统及计算机可读存储介质 |
US20180367456A1 (en) * | 2017-06-20 | 2018-12-20 | Cisco Technology, Inc. | System and method to facilitate packet forwarding using stateful bit index explicit replication (bier) in a networking environment |
CN114189473B (zh) * | 2019-06-06 | 2023-07-14 | 华为技术有限公司 | 一种报文的发送方法和装置 |
CN110784411B (zh) * | 2019-09-30 | 2021-10-01 | 华为技术有限公司 | 建立bier转发表项的方法、装置和系统 |
-
2021
- 2021-02-07 CN CN202110168399.4A patent/CN114945000B/zh active Active
-
2022
- 2022-01-27 WO PCT/CN2022/074403 patent/WO2022166773A1/zh active Application Filing
Patent Citations (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN104811387A (zh) * | 2014-01-24 | 2015-07-29 | 思科技术公司 | 具有位索引显式复制的等价多路径 |
US20190020583A1 (en) * | 2017-07-11 | 2019-01-17 | Cisco Technology, Inc. | Forwarding of Packets in a Network Based on Multiple Compact Forwarding Identifiers Represented in a Single Internet Protocol Version 6 (IPv6) Address |
CN109246017A (zh) * | 2018-11-28 | 2019-01-18 | 新华三技术有限公司 | 一种查询组播转发路径的方法及装置 |
CN111669330A (zh) * | 2019-03-08 | 2020-09-15 | 华为技术有限公司 | 一种bier报文的发送方法和装置 |
Non-Patent Citations (2)
Title |
---|
""Draft_MeetingReport#56bis__v0.0.1_cl"", 《3GPP TSG_CT\WG4_PROTOCOLLARS_EX-CN4》 * |
IJ. WIJNANDS等: "Multicast Using Bit Index Explicit Replication (BIER)", 《IETF RFC8279》 * |
Cited By (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
WO2024061184A1 (zh) * | 2022-09-22 | 2024-03-28 | 华为技术有限公司 | 对应关系的获取方法、参数通告方法、装置、设备及介质 |
WO2024067339A1 (zh) * | 2022-09-29 | 2024-04-04 | 中兴通讯股份有限公司 | 组播流量报文转发方法及系统、计算机设备及可读介质 |
Also Published As
Publication number | Publication date |
---|---|
CN114945000B (zh) | 2023-08-15 |
WO2022166773A1 (zh) | 2022-08-11 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US11700198B2 (en) | Transmission control method, node, network system and storage medium | |
CN109218178B (zh) | 一种报文处理方法及网络设备 | |
US8861547B2 (en) | Method, apparatus, and system for packet transmission | |
CN110460522B (zh) | 组播数据传输方法、相关装置及系统 | |
US11689452B2 (en) | Method for forwarding service data, network device, and network system | |
CN114945000B (zh) | 一种组播报文传输方法、位转发路由器及存储介质 | |
WO2020088696A1 (zh) | 报文转发的方法、发送报文的装置和接收报文的装置 | |
EP3002913B1 (en) | Tunnel establishment method, label allocation method, device, and network system | |
US7974223B2 (en) | Virtual private LAN service over ring networks | |
US7006499B2 (en) | Source identifier for MAC address learning | |
US7792123B2 (en) | Method and system for implementing hierarchical VPLS | |
US11792044B2 (en) | Offset label for aggregating multicasts from multiple virtual private networks on a single multicast distribution tree | |
US20070147372A1 (en) | Method for Implementing Multicast in Virtual Router-Based Virtual Private Network | |
US20040165600A1 (en) | Customer site bridged emulated LAN services via provider provisioned connections | |
EP2135393B1 (en) | Ethernet spanning tree provision | |
WO2022062506A1 (zh) | 一种数据处理方法、装置、存储介质及电子装置 | |
CN106603413B (zh) | 通过指定路径传输流量的方法和装置 | |
WO2017124709A1 (zh) | 流量工程隧道建立方法和装置 | |
JP2004534431A (ja) | ネットワークトンネリング | |
CN114465920B (zh) | 确定对应关系的方法、装置以及系统 | |
CN114095305A (zh) | Bier报文转发的方法、设备以及系统 | |
WO2013139270A1 (zh) | 实现三层虚拟专用网络的方法、设备及系统 | |
WO2017177756A1 (zh) | 一种信息传递方法、装置及系统 | |
CN113472665B (zh) | Evpn下不同组网对接的实现方法及装置 | |
CN103634210A (zh) | 发现vpls实例的对端pe设备的方法及设备 |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
PB01 | Publication | ||
PB01 | Publication | ||
SE01 | Entry into force of request for substantive examination | ||
SE01 | Entry into force of request for substantive examination | ||
GR01 | Patent grant | ||
GR01 | Patent grant |