CN108512762B - 一种组播实现方法及装置 - Google Patents
一种组播实现方法及装置 Download PDFInfo
- Publication number
- CN108512762B CN108512762B CN201810264219.0A CN201810264219A CN108512762B CN 108512762 B CN108512762 B CN 108512762B CN 201810264219 A CN201810264219 A CN 201810264219A CN 108512762 B CN108512762 B CN 108512762B
- Authority
- CN
- China
- Prior art keywords
- multicast
- ila
- bgp
- multicast source
- notification message
- 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.)
- Active
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/74—Address processing for 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/16—Multipoint routing
Landscapes
- Engineering & Computer Science (AREA)
- Computer Networks & Wireless Communication (AREA)
- Signal Processing (AREA)
- Data Exchanges In Wide-Area Networks (AREA)
Abstract
本发明提供一种组播实现方法及装置,该方法包括:当接收到BGP组播源通知消息时,生成对应的(S,G)表项,将数据中心互联DCI接口添加到该(S,G)表项的出接口,并根据组播源的位置Locator信息向组播源发送协议独立组播PIM加入消息;当接收到BGP组播接收者通知消息时,通过所述DCI接口发送组播侦听者发现MLD加入消息。应用本发明实施例可以提高组播流量的转发性能,减少时延,并可以实现ILA网络与Non‑ILA网络的组播通信。
Description
技术领域
本发明涉及网络通信技术领域,尤其涉及一种组播实现方法及装置。
背景技术
ILA(Identifier-Locator Addressing,标识位置寻址)技术是一种Overlay技术(一种应用层技术),面向IPv6(Internet Protocol Version 6,互联网协议版本6)的数据中心,利用IPv6的/64前缀作为位置标识,后64位地址作为虚机/容器等的ID(标识)。
与主流的VXLAN(Virtual Extensible Local Area Network,虚拟可扩展局域网)或LISP(Locator Identity Separation Protocol,定位标识分离协议)等技术不同,ILA不使用隧道封装方式建立Overlay网络(应用层网络),而是通过无状态NAT(Network AddressTranslation,网络地址转换)方式,连通Overlay网络和underlay网络(服务承载网络)。由于其地址替换是无状态的,使得硬件实现成本较低。
目前,ILA网络中的组播实现原理主要包括:组播源接入的主机或Leaf(叶)交换机将组播源发出的组播报文的源地址由SIR(Standard Identifier Representation,标准标识表述)地址替换为ILA地址;同时组播接收者接入的主机或Leaf交换机也要执行一次地址转换,将ILA地址替换回SIR地址。
然而实践发现,上述组播实现方案要求组播接收者均支持ILA地址替换,仅适用于ILA网络内部,无法满足ILA网络与外网之间的组播通信需求;此外,组播流量的转发需要经过地址转换,转发性能和延时会受到影响。
发明内容
本发明提供一种组播实现方法及装置,以解决现有ILA网络组播实现方案要求组播接收者均支持ILA地址替换,且转发性能差,延时高的问题。
根据本发明实施例的第一方面,提供一种组播实现方法,应用于ILA网络中的ILA路由器,所述ILA网络中的ILA路由器以及ILA主机或Leaf交换机之间建立有BGP邻居,该方法包括:
当接收到BGP组播源通知消息时,生成对应的(S,G)表项,将数据中心互联DCI接口添加到该(S,G)表项的出接口,并根据组播源的位置Locator信息向组播源发送协议独立组播PIM加入消息;其中,所述DCI接口为所述ILA路由器连接外部网络的接口,该BGP组播源通知消息携带有组播源的SIR地址信息、组播组地址信息以及组播源的Locator信息,该PIM加入消息携带逆向路径转发RPF向量,该RPF向量携带有该组播源的Locator信息;
当接收到BGP组播接收者通知消息时,通过所述DCI接口发送组播侦听者发现MLD加入消息;其中,该MLD加入消息中携带有该BGP组播接收者通知消息中携带的组播组地址信息。
根据本发明实施例的第二方面,提供一种组播实现方法,应用于ILA网络中的ILA主机或叶Leaf交换机,所述ILA网络中的ILA路由器以及ILA主机或Leaf交换机之间建立有BGP邻居,该方法包括:
当接收到本地组播源的组播流量时,生成对应的(S,G)表项,并发送BGP组播源通知消息;其中,该BGP组播源通知消息携带有组播源的SIR地址信息、组播组地址信息以及组播源的位置Locator信息;
当接收到组播侦听者发现MLD加入消息时,发送BGP组播接收者通知消息;其中,该BGP组播接收者通知消息中携带有该MLD加入消息中携带的组播组地址信息。
根据本发明实施例的第三方面,提供一种组播实现装置,应用于ILA网络中的ILA路由器,所述ILA网络中的ILA路由器以及ILA主机或Leaf交换机之间建立有BGP邻居,该装置包括:
接收单元,用于接收BGP组播源通知消息以及BGP组播接收者通知消息;
表项维护单元,用于当所述接收单元接收到BGP组播源通知消息时,生成对应的(S,G)表项,将数据中心互联DCI接口添加到该(S,G)表项的出接口;其中,所述DCI接口为所述ILA路由器连接外部网络的接口,该BGP组播源通知消息携带有组播源的SIR地址信息、组播组地址信息以及组播源的Locator信息;
发送单元,用于根据组播源的位置Locator信息向组播源发送协议独立组播PIM加入消息;其中,该PIM加入消息携带逆向路径转发RPF向量,该RPF向量携带有该组播源的Locator信息;
所述发送单元,还用于当所述接收单元接收到BGP组播接收者通知消息时,通过所述DCI接口发送组播侦听者发现MLD加入消息;其中,该MLD加入消息中携带有该BGP组播接收者通知消息中携带的组播组地址信息。
根据本发明实施例的第四方面,提供一种组播实现装置,应用于ILA网络中的ILA主机或叶Leaf交换机,所述ILA网络中的ILA路由器以及ILA主机或Leaf交换机之间建立有BGP邻居,该装置包括:
接收单元,用于接收组播流量以及MLD加入消息;
表项维护单元,用于当所述接收单元接收到本地组播源的组播流量时,生成对应的(S,G)表项;
发送单元,用于发送BGP组播源通知消息;其中,该BGP组播源通知消息携带有组播源的SIR地址信息、组播组地址信息以及组播源的位置Locator信息;
所述发送单元,还用于当所述接收单元接收到组播侦听者发现MLD加入消息时,发送BGP组播接收者通知消息;其中,该BGP组播接收者通知消息中携带有该MLD加入消息中携带的组播组地址信息。
应用本发明实施例,当ILA路由器接收到BGP组播源通知消息时,生成(S,G)表项,将DCI接口添加到该(S,G)表项的出接口,并根据组播源的Locator信息向组播源发送PIM加入消息,该PIM加入消息携带组播源的Locator作为RPF向量,以便ILA网络内的组播流量能够达到ILA路由器,并由ILA路由器通过DCI接口发送至Non-ILA网络;当ILA路由器接收到BGP组播接收者通知消息时,通过DCI接口发送MLD加入消息,以便Non-ILA网络的组播流量可以通过ILA路由器发送至ILA网络内的组播接收者,与现有ILA网络内的组播实现方案相比,不需要进行ILA地址转发,提高了组播流量的转发性能,减少了时延,并实现了ILA网络与Non-ILA网络的组播通信。
附图说明
图1是本发明实施例提供的一种组播实现的网络架构示意图;
图2是本发明实施例提供的一种组播实现方法的流程示意图;
图3是本发明实施例提供的一种组播实现方法的流程示意图;
图4是本发明实施例提供的一种具体应用场景的架构示意图;
图5是本发明实施例提供的一种组播实现装置的结构示意图;
图6是本发明实施例提供的一种组播实现装置的结构示意图;
图7是本发明实施例提供的另一种组播实现装置的结构示意图。
具体实施方式
为了使本技术领域的人员更好地理解本发明实施例中的技术方案,下面先对本发明实施例提供的技术方案使用的网络架构进行简单说明。
请参见图1,为本发明实施例提供一种的组播实现系统的网络架构示意图,如图1所示,该网络架构包括ILA网络和Non-ILA网络(非ILA网络,也可以称为外部网络),ILA网络可以以主机overlay方式存在(即通过ILA主机进行ILA地址转换),也可以通过网络overlay(即通过Leaf交换机完成ILA地址转换)方式部署(图1中以主机overlay为例,下文中也均以主机overlay为例),其中:
ILA网络中包括ILA路由器(图中仅示出ILA网络中与Non-ILA网络连接的ILA路由器)、ILA主机;ILA主机分配有ILA地址,ILA主机和ILA路由器的IPv6underlay网络可通。ILA主机上部署容器(Docker),该容器分配有SIR地址。
ILA路由器配置有SIR前缀;ILA路由器可以在ILA网络内通告SIR前缀,即整个ILA网络在一个SIR域;ILA路由器还可以向Non-ILA网络通告SIR前缀,保证ILA网络与Non-ILA网络之间可以互通。
在图1所示的网络架构中,ILA主机以及ILA路由器之间可以建立BGP(BorderGateway Protocol,边界网关协议)邻居。
一方面,当ILA主机确定本地存在组播源时,可以发送BGP组播源通知消息,以将组播源信息通知给各BGP邻居;其中,该BGP组播源通告消息可以包括组播源的SIR地址信息、组播组地址信息以及组播源的Locator信息(组播源接入的ILA主机的Locator)。
ILA路由器接收到BGP组播源通知消息时,可以生成对应的(S,G)表项,将DCI接口添加到该(S,G)表项的出接口,并向组播源发送携带组播源的Locator信息的PIM加入消息,以保证ILA路由器可以接收到组播源的组播流量,并将接收到组播流量通过DCI接口发送至Non-ILA网络,在不进行地址转换的情况下实现了ILA网络内的组播流量向Non-ILA网络的转发,保证Non-ILA网络中的组播接收者能够接收到ILA网络内的组播源发送的组播流量。
另一方面,当ILA主机确定本地存在组播接收者时,可以发送BGP组播接收者通知消息,以将组播接收者信息通知给各BGP邻居;其中,该BGP组播接收者通知消息中携带有组播组地址信息。
ILA路由器接收到BGP组播接收者通知消息时,可以通过DCI接口发送MLD(Multicast Listener Discover,组播侦听者发现)加入消息,以便Non-ILA网络内的组播流量可以通过ILA路由器发送至ILA网络内的组播接收者,在不进行地址转换的情况下实现了Non-ILA网络内的组播流量向ILA网络的转发,保证ILA网络中的组播接收者能够接收到Non-ILA网络内的组播源发送的组播流量。
需要说明的是,本发明实施例中ILA网络和Non-ILA网络均为IPv6网络;若未特殊说明,本文中所提及的ILA路由器均指ILA网络中与Non-ILA网络连接的路由器。
为了使本发明实施例的上述目的、特征和优点能够更加明显易懂,下面结合附图对本发明实施例中技术方案作进一步详细的说明。
请参见图2,为本发明实施例提供的一种组播实现方法的流程示意图,其中,该组播实现方法可以应用于ILA网络中的ILA路由器,如图2所示,该组播实现方法可以包括以下步骤:
步骤201、当接收到BGP组播源通知消息时,生成对应的(S,G)表项,将DCI接口添加到该(S,G)表项的出接口,并根据组播源的Locator信息向组播源发送PIM加入消息。
本发明实施例中,ILA主机发送BGP组播源通知消息的具体实现可以参见图3所示方法流程,本发明实施例在此不做赘述。
其中,BGP组播源通知消息中可以携带(S,G,Locator)信息,其中,S为组播源的SIR地址信息(即组播源地址信息),G为组播组地址信息,Locator为组播源的Locator信息。
其中,(S,G)表项即为组播源地址信息与组播组地址信息之间的对应关系表项。
本发明实施例中,ILA路由器接收到BGP组播源通知消息时,一方面,可以根据其中携带的组播源的SIR地址信息以及组播组地址信息,生成对应的(S,G)表项,并将DCI接口添加到该(S,G)表项的出接口,以便ILA路由器接收到该组播源的组播流量时,可以通过该DCI接口将组播流量转发至Non-ILA网络。
另一方面,ILA路由器可以向组播源发送PIM加入消息,该PIM加入消息中除了携带组播源的SIR地址信息以及组播组信息之外,还可以通过RPF(Reverse Path Forwarding,逆向路径转发)向量携带组播源的Locator信息;其中,ILA路由器与组播源接入的ILA主机之间的转发路径上的中间节点(如underlay路由器)可以根据该RPF向量中携带的组播源的Locator信息进行RPF检查,并在检查通过后,向指向组播源接入的ILA主机的上游接口发送PIM加入消息,该PIM加入消息中通过RPF向量携带组播源的Locator信息,直至组播源接入的ILA主机接收到PIM加入消息。
其中,组播源接入的ILA主机接收到PIM加入消息时的处理流程可以参见图3所示的方法流程,本发明实施例在此不做赘述。
步骤202、当接收到BGP组播接收者通知消息时,通过DCI接口发送MLD加入消息。
本发明实施例中,ILA主机发送BGP组播接收者通知消息的具体实现可以参见图3所示方法流程,本发明实施例在此不做赘述。
其中,BGP组播接收者通知消息中可以携带组播组地址信息。
本发明实施例中,ILA路由器接收到BGP组播接收者通知消息时,可以通过DCI接口向Non-ILA网络发送MLD加入消息,以便Non-ILA网络内的组播源获知ILA网络内存在组播接收者,进而,通过ILA路由器将Non-ILA网络内的组播流量转发至ILA网络。
其中,该MLD加入消息中携带有BGP组播接收者通知消息中携带的组播组地址信息。
进一步地,在本发明其中一个实施例中,上述通过DCI接口发送MLD加入消息之后,还可以包括:
当从DCI接口接收到组播组流量时,生成对应的(S,G)表项,并发送BGP组播源通知消息;
当接收到PIM加入消息时,将接收到该PIM加入消息的接口添加到对应的(S,G)表项的出接口。
在该实施例中,当ILA路由器从DCI接口接收到Non-ILA网络的组播流量(即Non-ILA网络的组播源的组播流量)时,ILA路由器可以将自身作为组播源接入的ILA主机(组播源为Non-ILA网络的组播源),一方面,根据该组播流量的组播源地址信息以及组播组地址信息生成对应的(S,G)表项,此时,该(S,G)表项的出接口为空。
另一方面,ILA路由器可以发送BGP组播源通知消息,以将组播源信息通知给各BGP邻居。
其中,该BGP组播源通知消息可以携带(S,G,Locator)信息,其中,S为ILA路由器接收到的组播流量的组播源地址,G为该组播流量的组播组地址,Locator为ILA路由器的Locator信息。
ILA主机接收到该BGP组播源通知消息时,可以记录其中携带的(S,G,Locator)信息,并当本地存在该组播组的组播接收者时,发送PIM加入消息,其具体实现可以参见图3所示方法流程,本发明实施例在此不做赘述。
在该实施例中,当ILA路由器接收到PIM加入消息时,ILA路由器可以将接收到该PIM加入消息的接口添加到该组播流量对应的(S,G)表项的出接口,进而,ILA路由器可以通过该接口将Non-ILA网络中的该组播源的该组播组地址的组播流量转发给ILA网络内的组播接收者。
请参见图3,为本发明实施例提供的一种组播实现方法的流程示意图,其中,该组播实现方法可以应用于ILA网络中的ILA主机或Leaf交换机(本文中以ILA主机为例),如图3所示,该组播实现方法可以包括以下步骤:
步骤301、当接收到本地组播源的组播流量时,生成对应的(S,G)表项,并发送BGP组播源通知消息。
本发明实施例中,当ILA主机接收到本地组播源的组播流量时,一方面,ILA主机可以根据该组播流量的组播源地址信息(SIR地址)和组播组地址生成对应的(S,G)表项,此时,该(S,G)表项的出接口为空。
另一方面,ILA主机可以发送BGP组播源通知消息,以将组播源信息通知给各BGP邻居。
其中,该BGP组播源通知消息中可以携带(S,G,Locator)信息,其中,S为组播源的SIR地址信息(即组播源地址信息),G为组播组地址信息,Locator为组播源的Locator信息。
其中,ILA路由器接收到BGP组播源通知消息时的处理流程可以参见图2所示方法实施例中的相关描述,本发明实施例在此不再赘述。
本发明实施例中,当ILA主机接收到BGP组播源通知消息(包括其它ILA主机发送的BGP组播源通知消息或ILA路由器发送的BGP组播源通知消息)时,ILA主机可以记录该BGP组播源通知消息中携带的(S,G,Locator)信息;其中,S为组播源地址信息(当组播源为ILA网络内的组播源时,该地址信息为SIR地址信息),G为组播组地址信息,Locator为组播源的Locator信息(当组播源为Non-ILA网络内的组播源时,组播源的Locator信息为ILA路由器的Locator信息)。
当ILA主机确定本地存在该组播组的接收者时,ILA主机可以根据组播源的Locator信息向组播源发送PIM加入消息;其中,该PIM加入消息中除了携带组播源的地址信息以及组播组地址信息之外,还携带有RPF向量,该RPF向量中携带有组播源的Locator信息。
其中,ILA主机与组播源之间的转发路径上的中间节点(如underlay路由器)可以根据该RPF向量中携带的组播源的Locator信息进行RPF检查,并在检查通过后,向指向组播源的上游接口(即接收到该组播源发送的BGP组播源通知消息的接口)发送PIM加入消息,该PIM加入消息中通过RPF向量携带组播源的Locator信息,直至组播源接入的ILA主机(组播源在ILA网络内)或ILA路由器(组播源在Non-ILA网络内)接收到PIM加入消息。
本发明实施例中,ILA路由器接收到PIM加入消息时的处理流程可以参见图2所示方法流程中的相关描述,本发明实施例在此不再赘述。
ILA主机接收到PIM加入消息时,可以将接收该PIM加入消息的接口添加到对应的(S,G)表项的出接口。
由于ILA路由器接收到ILA主机发送的BGP组播源通知消息时,会将DCI接口加入到对应的(S,G)表项的出接口,并向ILA主机发送PIM加入消息,因此,ILA主机接收到本地组播源的组播流量时,会将组播流向ILA路由器发送,进而,当ILA路由器接收到该组播流量时,查询对应的(S,G)表项之后,可以通过DCI接口向Non-ILA网络转发,保证了Non-ILA网络内的组播接收者可以接收到ILA网络内的组播源的组播流量。
其中,Non-ILA网络的路由器接收到组播流量时,可以根据正常的PIM等组播行为进行转发处理,其具体实现可以参见现有技术中的相关实现,本发明实施例对此不做限定。
步骤302、当接收到MLD加入消息时,发送BGP组播接收者通知消息。
本发明实施例中,当ILA主机本地存在组播接收者时,该组播接收者可以向ILA主机发送MLD加入消息,该MLD加入消息中可以携带组播组地址信息(组播接收者请求加入的组播组地址信息)。
可选地,该MLD加入消息中还可以携带组播源地址信息。
本发明实施例中,ILA主机接收到MLD加入消息时,ILA主机可以发送BGP组播接收者通知消息,以将ILA主机本地存在组播接收者的情况通知各BGP邻居(包括ILA路由器和其它ILA主机);其中,该BGP组播接收者通知消息可以携带MLD加入消息中携带的组播组地址信息。
可选地,当ILA主机接收到的MLD加入消息中携带有组播源地址信息时,该BGP组播接收者通知消息还可以携带MLD加入消息中携带的组播组地址信息。
其中,ILA路由器接收到BGP组播接收者通知消息时的处理流程可以参见图2所示方法流程中的相关描述,本发明实施例在此不再赘述。
进一步地,在本发明实施例中,当ILA主机本地组播源对应的(S,G)表项老化时,如该(S,G)表项对应的老化定时器超时,ILA主机可以发送BGP组播源撤销通知消息,以将该组播源离开的消息通知给各BGP邻居。
其中,该BGP组播源撤销通知消息中携带有(S,G,Locator)信息,其中,S为组播源地址信息(SIR地址),G为组播组地址信息,Locator为组播源的Locator信息。
ILA主机接收到其它ILA主机发送的BGP组播源撤销通知消息时,可以删除自身记录的对应的(S,G,Locator)信息,删除自身生成的对应的(S,G)表项(若存在),并进行剪枝处理。
ILA路由器接收到BGP组播源撤销通知消息时,可以删除自身生成的对应的(S,G)表项,并进行剪枝处理。
进一步地,在本发明实施例中,当ILA主机接收到本地组播接收者发送的离开消息时,ILA主机可以发送BGP组播接收者撤销消息,以将组播接收者离开的消息通知给各BGP邻居。
其中,该BGP组播接收者撤销消息可以携带有组播组地址信息。
ILA路由器接收到BGP组播接收者撤销通知消息时,可以更新自身生成的对应的(S,G)表项的出接口信息,并当确定ILA网络中不存在该组播组的接收者时,ILA路由器可以通过DCI接口发送MLD done(离开)报文,该MDL done报文中携带有该组播组地址信息,进而,Non-ILA网络中该组播组的组播流量不会再发送给ILA网络。
进一步地,在本发明实施例中,组播源迁移后,组播源迁移到的其他ILA主机会收到组播流量后,发送新的BGP组播源通知消息(携带(S,G,Locator)信息),触发在underlay网络建立新的组播转发路径,其具体实现可以参见上述方法流程中ILA主机确定本地存在组播源时的相关处理流程。
其中,组播源迁移前接入的ILA主机可以按照上述方法流程中描述的方式进行组播源离开处理,本发明实施例对此不再赘述。
同理,当组播接收者迁移后,组播接收者迁移到的其他ILA主机会发送BGP组播接收者通知消息、PIM加入消息等,其具体实现可以参见上述方法流程中的ILA主机确定本地存在组播接收者时的相关处理流程。
其中,组播接收者迁移前接入的ILA主机可以根据本地MLD组情况,判断是否剪枝,即当本地还存在同一组播组的其它组播接收者时,不进行剪枝处理;若本地不存在同一组播组的其它组播接收者时,进行剪枝处理,其具体实现在此不做赘述。
为了使本领域技术人员更好地理解本发明实施例提供的技术方案,下面结合具体应用场景对本发明实施例提供的技术方案进行说明。
请参见图4,为本发明实施例提供的一种具体应用场景的示意图,如图4所示,ILA网络中的ILA路由器通过DCI接口与Non-ILA网络相连,ILA网络内ILA主机以及ILA路由器之间建立MP-IBGP(Multiprotocol-Internal Border Gateway Protocol,多协议内部边界网关协议)邻居。假设所有组播源和接收者都接收同一个IPv6组播组。初始情况下,ILA网络中组播源S1发送组播流量,使用SIR地址face:b00c::1234。
基于图4所示场景,本发明实施例提供的组播实现方案流程如下:
1、ILA主机1接收到本地组播源(组播源S1)的组播流量,建立对应的(S,G)表项(初始状态出接口为空),并通过MP-BGP消息将(S,G,Locator)信息通知给各BGP peer(对端)(包括ILA主机2和ILA路由器)。
在该实施例中,可以通过对MP-BGP协议进行扩展,新增“vpn(Virtual PrivateNetwork,虚拟专用网)-sir-multicast(组播)”SAFI(Sub-Address Family Information,子地址族信息),包含2个Type(类型),分别对应组播源信息和组播接收者信息。
其中,当Type=1时,代表携带的是组播源信息,即(S,G,Locator)信息,对应的MP-BGP消息即为BGP组播源通知消息。
该消息用于通告ILA主机本地直连的组播源,其中组播源地址是组播源(如虚机)的SIR地址,Locator是SIR域所对应的Locator信息(ILA主机的Locator信息)。
当Type=2时,代表携带的是组播组加入信息,对应的MP-BGP消息即为BGP组播源通知消息。
其中,该MP-BGP消息可以携带组播组地址信息(对应MLDv1)或组播组地址信息和组播源地址信息(对应MLDv2)。
2、ILA路由器接收到Type=1的MP-BGP消息,生成对应的(S,G)表项,将DCI接口添加到该(S,G)表项的出接口,并向组播源发送PIM加入消息,该PIM加入消息携带RPF向量,该RPF向量携带有该MP-BGP消息中携带的Locator信息。
其中,underlay路由器收到PIM加入消息时,由于RPF向量携带了Locator信息,因此不再以组播源地址作为依据,而是按照Locator地址,进行RPF检查,并在检查通过后建立(S,G)表项,上游接口指向了ILA主机1,向其继续发送PIM加入消息,携带组播源的Locator信息作为RPF向量。
ILA主机1接收到PIM加入消息时,将接收到该PIM加入消息的接口添加到对应的(S,G)表项的出接口。
3、ILA主机2接收到Type=1的MP-BGP消息,记录其中携带的(S,G,Locator)信息。
4、组播源S1的组播流量根据ILA主机1生成的(S,G)表项的出接口进行转发;ILA路由器接收到该组播流量时,通过DCI接口发送至Non-ILA网络的路由器;Non-ILA网络的路由器可以根据正常的PIM等组播行为进行转发处理,其具体实现可以参见现有技术中的相关实现,本发明实施例对此不做限定。
5、ILA主机2接收到本地组播接收者的MLD加入消息时,查询自身记录有对应的(S,G,Locator)信息,生成对应的(S,G)表项,并向组播源发送PIM加入消息,携带组播源的Locator信息作为RPF向量。
ILA主机1接收到该PIM加入消息时,将接收到该PIM加入消息的接口添加到对应的(S,G)表项的出接口,进而,ILA主机1的组播流量也可以发送至ILA主机2连接的组播接收者R1。
此外,ILA主机2还可以通过Type=2的MP-BGP消息通知BGP peer本地存在组播组G的组播接收者。
6、ILA路由器接收到Type=2的MP-BGP消息,通过DCI接口发送MLD加入消息,以便将Non-ILA网络的组播流量引入ILA网络。
7、当ILA路由器从DCI接口接收到组播流量时,ILA路由器可以生成对应的(S,G)表项(初始状态出接口为空),并发送Type=1的MP-BGP消息,携带(S,G,Locator)信息。
其中,S为ILA路由器从DCI接口接收到的组播流量的组播源地址信息,G为该组播流量的组播组地址,Locator为ILA路由器的Locator信息。
8、ILA主机1和ILA主机2接收到该Type=1的MP-BGP消息,记录其中携带的(S,G,Locator)信息。
由于ILA主机2本地存在组播接收者,ILA主机2向ILA路由器发送PIM加入消息,该PIM加入消息携带ILA路由器的Locator信息作为RPF向量。
ILA路由器接收到PIM加入消息时,将接收到该PIM加入消息的接口添加到对应的(S,G)表项的出接口。
通过以上描述可以看出,在本发明实施例提供的技术方案中,当ILA路由器接收到BGP组播源通知消息时,生成(S,G)表项,将DCI接口添加到该(S,G)表项的出接口,并根据组播源的Locator信息向组播源发送PIM加入消息,该PIM加入消息携带组播源的Locator作为RPF向量,以便ILA网络内的组播流量能够达到ILA路由器,并由ILA路由器通过DCI接口发送至Non-ILA网络;当ILA路由器接收到BGP组播接收者通知消息时,通过DCI接口发送MLD加入消息,以便Non-ILA网络的组播流量可以通过ILA路由器发送至ILA网络内的组播接收者,与现有ILA网络内的组播实现方案相比,不需要进行ILA地址转发,提高了组播流量的转发性能,减少了时延,并实现了ILA网络与Non-ILA网络的组播通信。
请参见图5,为本发明实施例提供的一种组播实现装置的结构示意图,其中,该装置可以应用于上述方法实施例中的ILA路由器,如图5所示,该组播实现装置可以包括:
接收单元510,用于接收BGP组播源通知消息以及BGP组播接收者通知消息;
表项维护单元520,用于当所述接收单元510接收到BGP组播源通知消息时,生成对应的(S,G)表项,将数据中心互联DCI接口添加到该(S,G)表项的出接口;其中,所述DCI接口为所述ILA路由器连接外部网络的接口,该BGP组播源通知消息携带有组播源的SIR地址信息、组播组地址信息以及组播源的Locator信息;
发送单元530,用于根据组播源的位置Locator信息向组播源发送协议独立组播PIM加入消息;其中,该PIM加入消息携带逆向路径转发RPF向量,该RPF向量携带有该组播源的Locator信息;
所述发送单元530,还用于当所述接收单元510接收到BGP组播接收者通知消息时,通过所述DCI接口发送组播侦听者发现MLD加入消息;其中,该MLD加入消息中携带有该BGP组播接收者通知消息中携带的组播组地址信息。
在可选实施例中,所述表项维护单元520,还用于当所述接收单元510从所述DCI接口接收到非ILA网络的组播流量时,生成对应的(S,G)表项;
所述发送单元530,还用于发送BGP组播源通知消息;其中,该BGP组播源通知消息包括该组播流量的组播源地址、组播组地址以及所述ILA路由器的Locator信息;
所述表项维护单元520,还用于当所述接收单元510接收到PIM加入消息时,将接收到该PIM加入消息的接口添加到对应的(S,G)表项的出接口。
在可选实施例中,所述发送单元530,还用于当所述接收单元510接收到BGP组播接收者撤销通知消息,且确定所述ILA网络中不存在目标组播组的接收者时,通过所述DCI接口发送MLD离开组done报文;其中,该BGP组播接收者撤销通知消息中携带有该目标组播组地址信息,该MLD done报文中携带有该目标组播组地址信息。
请参见图6,为本发明实施例提供的一种组播实现装置的结构示意图,其中,该装置可以应用于上述方法实施例中的ILA主机或Leaf交换机,如图6所示,该组播实现装置可以包括:
接收单元610,用于接收组播流量以及MLD加入消息;
表项维护单元620,用于当所述接收单元610接收到本地组播源的组播流量时,生成对应的(S,G)表项;
发送单元630,用于发送BGP组播源通知消息;其中,该BGP组播源通知消息携带有组播源的SIR地址信息、组播组地址信息以及组播源的位置Locator信息;
所述发送单元630,还用于当所述接收单元610接收到组播侦听者发现MLD加入消息时,发送BGP组播接收者通知消息;其中,该BGP组播接收者通知消息中携带有该MLD加入消息中携带的组播组地址信息。
在可选实施例中,所述表项维护单元620,还用于当所述接收单元610接收到PIM加入消息时,将接收到该PIM加入消息的接口添加到对应的(S,G)表项的出接口。
请一并参见图7,为本发明实施例提供的另一种组播实现装置的结构示意图,如图7所示,在图6所示组播实现装置的基础上,图7所示组播实现装置还包括:
记录单元640,用于当所述接收单元610接收到BGP组播源通知消息时,记录该BGP组播源通知消息中携带的组播源地址、组播组地址以及组播源的Locator信息;其中,该BGP组播源通知消息携带有组播源的地址信息、组播组地址信息以及组播源的Locator信息;
所述发送单元630,还用于当本地存在该组播组的接收者时,根据组播源的Locator信息向组播源发送PIM加入消息;其中,该PIM加入消息携带逆向路径转发RPF向量,该RPF向量携带有该组播源的Locator信息。
在可选实施例中,所述发送单元630,还用于当所述接收单元接收到本地组播接收者发送的离开消息时,发送BGP组播接收者撤销通知消息;其中,该BGP组播接收者撤销通知消息中携带有组播组地址信息。
上述装置中各个单元的功能和作用的实现过程具体详见上述方法中对应步骤的实现过程,在此不再赘述。
对于装置实施例而言,由于其基本对应于方法实施例,所以相关之处参见方法实施例的部分说明即可。以上所描述的装置实施例仅仅是示意性的,其中所述作为分离部件说明的单元可以是或者也可以不是物理上分开的,作为单元显示的部件可以是或者也可以不是物理单元,即可以位于一个地方,或者也可以分布到多个网络单元上。可以根据实际的需要选择其中的部分或者全部模块来实现本发明方案的目的。本领域普通技术人员在不付出创造性劳动的情况下,即可以理解并实施。
由上述实施例可见,当ILA路由器接收到BGP组播源通知消息时,生成(S,G)表项,将DCI接口添加到该(S,G)表项的出接口,并根据组播源的Locator信息向组播源发送PIM加入消息,该PIM加入消息携带组播源的Locator作为RPF向量,以便ILA网络内的组播流量能够达到ILA路由器,并由ILA路由器通过DCI接口发送至Non-ILA网络;当ILA路由器接收到BGP组播接收者通知消息时,通过DCI接口发送MLD加入消息,以便Non-ILA网络的组播流量可以通过ILA路由器发送至ILA网络内的组播接收者,与现有ILA网络内的组播实现方案相比,不需要进行ILA地址转发,提高了组播流量的转发性能,减少了时延,并实现了ILA网络与Non-ILA网络的组播通信。
本领域技术人员在考虑说明书及实践这里公开的发明后,将容易想到本发明的其它实施方案。本申请旨在涵盖本发明的任何变型、用途或者适应性变化,这些变型、用途或者适应性变化遵循本发明的一般性原理并包括本发明未公开的本技术领域中的公知常识或惯用技术手段。说明书和实施例仅被视为示例性的,本发明的真正范围和精神由下面的权利要求指出。
应当理解的是,本发明并不局限于上面已经描述并在附图中示出的精确结构,并且可以在不脱离其范围进行各种修改和改变。本发明的范围仅由所附的权利要求来限制。
Claims (14)
1.一种组播实现方法,应用于标识位置寻址ILA网络中的ILA路由器,其特征在于,所述ILA网络中的ILA路由器以及ILA主机或Leaf交换机之间建立有边界网关协议BGP邻居,该方法包括:
当接收到BGP组播源通知消息时,生成对应的(S,G)表项,将数据中心互联DCI接口添加到该(S,G)表项的出接口,并根据组播源的位置Locator信息向组播源发送协议独立组播PIM加入消息;其中,所述DCI接口为所述ILA路由器连接外部网络的接口,该BGP组播源通知消息携带有组播源的标准标识表述SIR地址信息、组播组地址信息以及组播源的Locator信息,该PIM加入消息携带逆向路径转发RPF向量,该RPF向量携带有该组播源的Locator信息;其中,(S,G)中的S为组播源的SIR地址信息,G为组播组地址信息;
当接收到BGP组播接收者通知消息时,通过所述DCI接口发送组播侦听者发现MLD加入消息;其中,该MLD加入消息中携带有该BGP组播接收者通知消息中携带的组播组地址信息。
2.根据权利要求1所述的方法,其特征在于,所述通过所述DCI接口发送组播侦听者发现MLD加入消息之后,还包括:
当从所述DCI接口接收到非ILA网络的组播流量时,生成对应的(S,G)表项,并发送BGP组播源通知消息;其中,该BGP组播源通知消息包括该组播流量的组播源地址、组播组地址以及所述ILA路由器的Locator信息;
当接收到PIM加入消息时,将接收到该PIM加入消息的接口添加到对应的(S,G)表项的出接口。
3.根据权利要求1所述的方法,其特征在于,所述方法还包括:
当接收到BGP组播接收者撤销通知消息,且确定所述ILA网络中不存在目标组播组的接收者时,通过所述DCI接口发送MLD离开组done报文;其中,该BGP组播接收者撤销通知消息中携带有该目标组播组地址信息,该MLD done报文中携带有该目标组播组地址信息。
4.一种组播实现方法,应用于标识位置寻址ILA网络中的ILA主机或叶Leaf交换机,其特征在于,所述ILA网络中的ILA路由器以及ILA主机或Leaf交换机之间建立有边界网关协议BGP邻居,所述ILA路由器用于执行权利要求1~3任一项所述的方法;该方法包括:
当接收到本地组播源的组播流量时,生成对应的(S,G)表项,并发送BGP组播源通知消息;其中,该BGP组播源通知消息携带有组播源的标准标识表述SIR地址信息、组播组地址信息以及组播源的位置Locator信息;其中,(S,G)中的S为组播源的SIR地址信息,G为组播组地址信息;
当接收到组播侦听者发现MLD加入消息时,发送BGP组播接收者通知消息;其中,该BGP组播接收者通知消息中携带有该MLD加入消息中携带的组播组地址信息。
5.根据权利要求4所述的方法,其特征在于,所述方法还包括:
当接收到协议独立组播PIM加入消息时,将接收到该PIM加入消息的接口添加到对应的(S,G)表项的出接口。
6.根据权利要求4所述的方法,其特征在于,所述方法还包括:
当接收到BGP组播源通知消息时,记录该BGP组播源通知消息中携带的组播源地址、组播组地址以及组播源的Locator信息;其中,该BGP组播源通知消息携带有组播源的地址信息、组播组地址信息以及组播源的Locator信息;
当本地存在该组播组的接收者时,根据组播源的Locator信息向组播源发送PIM加入消息;其中,该PIM加入消息携带逆向路径转发RPF向量,该RPF向量携带有该组播源的Locator信息。
7.根据权利要求4所述的方法,其特征在于,
当接收到本地组播接收者发送的离开消息时,发送BGP组播接收者撤销通知消息;其中,该BGP组播接收者撤销通知消息中携带有组播组地址信息。
8.一种组播实现装置,应用于标识位置寻址ILA网络中的ILA路由器,其特征在于,所述ILA网络中的ILA路由器以及ILA主机或Leaf交换机之间建立有边界网关协议BGP邻居,该装置包括:
接收单元,用于接收BGP组播源通知消息以及BGP组播接收者通知消息;
表项维护单元,用于当所述接收单元接收到BGP组播源通知消息时,生成对应的(S,G)表项,将数据中心互联DCI接口添加到该(S,G)表项的出接口;其中,所述DCI接口为所述ILA路由器连接外部网络的接口,该BGP组播源通知消息携带有组播源的标准标识表述SIR地址信息、组播组地址信息以及组播源的Locator信息;其中,(S,G)中的S为组播源的SIR地址信息,G为组播组地址信息;
发送单元,用于根据组播源的位置Locator信息向组播源发送协议独立组播PIM加入消息;其中,该PIM加入消息携带逆向路径转发RPF向量,该RPF向量携带有该组播源的Locator信息;
所述发送单元,还用于当所述接收单元接收到BGP组播接收者通知消息时,通过所述DCI接口发送组播侦听者发现MLD加入消息;其中,该MLD加入消息中携带有该BGP组播接收者通知消息中携带的组播组地址信息。
9.根据权利要求8所述的装置,其特征在于,
所述表项维护单元,还用于当所述接收单元从所述DCI接口接收到非ILA网络的组播流量时,生成对应的(S,G)表项;
所述发送单元,还用于发送BGP组播源通知消息;其中,该BGP组播源通知消息包括该组播流量的组播源地址、组播组地址以及所述ILA路由器的Locator信息;
所述表项维护单元,还用于当所述接收单元接收到PIM加入消息时,将接收到该PIM加入消息的接口添加到对应的(S,G)表项的出接口。
10.根据权利要求8所述的装置,其特征在于,
所述发送单元,还用于当所述接收单元接收到BGP组播接收者撤销通知消息,且确定所述ILA网络中不存在目标组播组的接收者时,通过所述DCI接口发送MLD离开组done报文;其中,该BGP组播接收者撤销通知消息中携带有该目标组播组地址信息,该MLD done报文中携带有该目标组播组地址信息。
11.一种组播实现装置,应用于标识位置寻址ILA网络中的ILA主机或叶Leaf交换机,其特征在于,所述ILA网络中的ILA路由器以及ILA主机或Leaf交换机之间建立有边界网关协议BGP邻居,所述ILA路由器用于执行权利要求1~3任一项所述的方法;该装置包括:
接收单元,用于接收组播流量以及组播侦听者发现MLD加入消息;
表项维护单元,用于当所述接收单元接收到本地组播源的组播流量时,生成对应的(S,G)表项;其中,(S,G)中的S为组播源的标准标识表述SIR地址信息,G为组播组地址信息;
发送单元,用于发送BGP组播源通知消息;其中,该BGP组播源通知消息携带有组播源的SIR地址信息、组播组地址信息以及组播源的位置Locator信息;
所述发送单元,还用于当所述接收单元接收到组播侦听者发现MLD加入消息时,发送BGP组播接收者通知消息;其中,该BGP组播接收者通知消息中携带有该MLD加入消息中携带的组播组地址信息。
12.根据权利要求11所述的装置,其特征在于,
所述表项维护单元,还用于当所述接收单元接收到协议独立组播PIM加入消息时,将接收到该PIM加入消息的接口添加到对应的(S,G)表项的出接口。
13.根据权利要求11所述的装置,其特征在于,所述装置还包括:
记录单元,用于当所述接收单元接收到BGP组播源通知消息时,记录该BGP组播源通知消息中携带的组播源地址、组播组地址以及组播源的Locator信息;其中,该BGP组播源通知消息携带有组播源的地址信息、组播组地址信息以及组播源的Locator信息;
所述发送单元,还用于当本地存在该组播组的接收者时,根据组播源的Locator信息向组播源发送PIM加入消息;其中,该PIM加入消息携带逆向路径转发RPF向量,该RPF向量携带有该组播源的Locator信息。
14.根据权利要求11所述的装置,其特征在于,
所述发送单元,还用于当所述接收单元接收到本地组播接收者发送的离开消息时,发送BGP组播接收者撤销通知消息;其中,该BGP组播接收者撤销通知消息中携带有组播组地址信息。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201810264219.0A CN108512762B (zh) | 2018-03-28 | 2018-03-28 | 一种组播实现方法及装置 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201810264219.0A CN108512762B (zh) | 2018-03-28 | 2018-03-28 | 一种组播实现方法及装置 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN108512762A CN108512762A (zh) | 2018-09-07 |
CN108512762B true CN108512762B (zh) | 2021-02-26 |
Family
ID=63379014
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN201810264219.0A Active CN108512762B (zh) | 2018-03-28 | 2018-03-28 | 一种组播实现方法及装置 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN108512762B (zh) |
Citations (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN102158405A (zh) * | 2011-03-31 | 2011-08-17 | 杭州华三通信技术有限公司 | 双向协议无关组播网络中组播转发表项建立方法及设备 |
CN102263695A (zh) * | 2011-07-27 | 2011-11-30 | 中兴通讯股份有限公司 | 组播跨越ldp网络的方法及系统 |
Family Cites Families (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US7769885B1 (en) * | 2003-05-23 | 2010-08-03 | Juniper Networks, Inc. | Determining liveness of protocols and interfaces |
-
2018
- 2018-03-28 CN CN201810264219.0A patent/CN108512762B/zh active Active
Patent Citations (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN102158405A (zh) * | 2011-03-31 | 2011-08-17 | 杭州华三通信技术有限公司 | 双向协议无关组播网络中组播转发表项建立方法及设备 |
CN102263695A (zh) * | 2011-07-27 | 2011-11-30 | 中兴通讯股份有限公司 | 组播跨越ldp网络的方法及系统 |
Also Published As
Publication number | Publication date |
---|---|
CN108512762A (zh) | 2018-09-07 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US11398921B2 (en) | SDN facilitated multicast in data center | |
US9871718B2 (en) | Method and device for registering multicast source and establishing multicast path | |
US9749214B2 (en) | Software defined networking (SDN) specific topology information discovery | |
US9509609B2 (en) | Forwarding packets and PE devices in VPLS | |
CN108964940B (zh) | 消息发送方法及装置、存储介质 | |
US20150254149A1 (en) | Dual Adjacency Between Edge Devices at a Network Site | |
CN109561033B (zh) | Overlay网络中组播复制的方法及装置 | |
CN105264493A (zh) | 信息中心网络上的动态虚拟机迁移 | |
US9288067B2 (en) | Adjacency server for virtual private networks | |
US11394578B2 (en) | Supporting multicast over a network domain | |
CN107612809A (zh) | 一种组播表项同步方法以及设备 | |
WO2021143279A1 (zh) | 段路由业务处理方法和装置、路由设备及存储介质 | |
US20230308391A1 (en) | Communication of policy changes in lisp-based software defined networks | |
EP2892196B1 (en) | Method, network node and system for implementing point-to-multipoint multicast | |
CN110120906B (zh) | 用于实现双活接入trill园区边缘的方法和设备 | |
US9548887B2 (en) | Proactive creation of multicast state in an overlay transport network to achieve fast convergence on failover | |
US20220094626A1 (en) | Method and Apparatus for Implementing Multicast | |
CN108512762B (zh) | 一种组播实现方法及装置 | |
CN115118545B (zh) | 以太网虚拟专用网多播网络中的组管理协议主机移动性 | |
Jeong et al. | Lisp controller: a centralized lisp management system for isp networks | |
US9876736B2 (en) | Dual stack root based mLDP tree merge | |
WO2015039563A1 (zh) | 实现三层虚拟专用网的方法和设备 | |
JP2016149701A (ja) | ネットワークシステムおよびパケット転送方法 | |
CN104243260A (zh) | 以太网虚拟化互联网络互连方法及边缘设备 | |
WO2017079901A1 (zh) | 一种路由方法及路由装置 |
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 |