CN111585900B - 基于sdn控制器在主机覆盖网络的组播方法 - Google Patents

基于sdn控制器在主机覆盖网络的组播方法 Download PDF

Info

Publication number
CN111585900B
CN111585900B CN202010364674.5A CN202010364674A CN111585900B CN 111585900 B CN111585900 B CN 111585900B CN 202010364674 A CN202010364674 A CN 202010364674A CN 111585900 B CN111585900 B CN 111585900B
Authority
CN
China
Prior art keywords
information
virtual port
multicast group
multicast
address
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
Application number
CN202010364674.5A
Other languages
English (en)
Other versions
CN111585900A (zh
Inventor
黄斌
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Ping An Technology Shenzhen Co Ltd
Original Assignee
Ping An Technology Shenzhen Co Ltd
Priority date (The priority date 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 date listed.)
Filing date
Publication date
Application filed by Ping An Technology Shenzhen Co Ltd filed Critical Ping An Technology Shenzhen Co Ltd
Priority to CN202010364674.5A priority Critical patent/CN111585900B/zh
Publication of CN111585900A publication Critical patent/CN111585900A/zh
Priority to PCT/CN2020/118903 priority patent/WO2021218026A1/zh
Application granted granted Critical
Publication of CN111585900B publication Critical patent/CN111585900B/zh
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L45/00Routing or path finding of packets in data switching networks
    • H04L45/16Multipoint routing
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L12/00Data switching networks
    • H04L12/28Data switching networks characterised by path configuration, e.g. LAN [Local Area Networks] or WAN [Wide Area Networks]
    • H04L12/46Interconnection of networks
    • H04L12/4633Interconnection of networks using encapsulation techniques, e.g. tunneling
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L12/00Data switching networks
    • H04L12/28Data switching networks characterised by path configuration, e.g. LAN [Local Area Networks] or WAN [Wide Area Networks]
    • H04L12/46Interconnection of networks
    • H04L12/4641Virtual LANs, VLANs, e.g. virtual private networks [VPN]
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L45/00Routing or path finding of packets in data switching networks
    • H04L45/74Address processing for routing
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L61/00Network arrangements, protocols or services for addressing or naming
    • H04L61/50Address allocation
    • H04L61/5007Internet protocol [IP] addresses

Landscapes

  • Engineering & Computer Science (AREA)
  • Computer Networks & Wireless Communication (AREA)
  • Signal Processing (AREA)
  • Computer Security & Cryptography (AREA)
  • Data Exchanges In Wide-Area Networks (AREA)

Abstract

本发明涉及人工智能技术领域,公开了一种基于SDN控制器在主机覆盖网络的组播方法及系统,采用SDN控制器集中控制覆盖网络的组播组信息,根据控制器对全网拓扑的了解生成组播流量规则,并下发到主机上的分布式虚拟路由器执行,在数据面流表投递的时候,根据获取到的接口信息直接将报文信息发往组播组成员所在的接口,使用精准地投递方式,较好的抑制了组播报文在二层的泛洪问题,解决了网路负担较重的现象。

Description

基于SDN控制器在主机覆盖网络的组播方法
技术领域
本发明涉及人工智能中的互联网技术领域,特别是涉及一种基于SDN控制器在主机覆盖网络的组播方法和相应的一种基于SDN控制器在主机覆盖网络的组播系统。
背景技术
覆盖网络是将一个逻辑网络建立在一个实体网络之上,将二层数据包重新封装在用户数据报协议中,现有的覆盖网络针对物理服务器,采用物理交换机作为边缘设备。
现有的单播、广播和组播方式都存在着一定的弊端,在广播方式下,信息会发送到不需要该信息的主机,从而浪费带宽资源,甚至引起广播风暴;而单播方式下,会因为数据包的多次重复而浪费带宽资源。
仅采用组播方式同样会因为大二层网络里每个虚拟网络的广播域会扩展到所有的VNE设备上,由此带来泛洪的问题,广播报文会泛洪到广播域内所有主机上,而主机数量可能多达数百台,从而对网络造成重大负担。
发明内容
鉴于上述问题,提出了本发明实施例以便提供一种克服上述问题或者至少部分地解决上述问题的一种基于SDN控制器在主机覆盖网络的组播方法和相应的一种基于SDN控制器在主机覆盖网络的组播系统。
为了解决上述问题,本发明实施例公开了一种基于SDN控制器的组播方法,应用于主机覆盖网络中,所述主机覆盖网络包括隧道、位于所述隧道两端的源虚拟端口和对端虚拟端口,包括步骤:
通过所述主机覆盖网络获取源虚拟端口信息,其中,所述源虚拟端口信息包括组播组、对端虚拟端口位置信息和报文信息,所述对端虚拟端口位置信息包括组播组的IP地址和成员信息;
根据所述成员信息解析出目的接口信息;
虚拟交换机根据所述目的接口信息、所述报文信息和所述组播组的IP地址生成数据面流表,按照所述数据面流表转发所述报文信息。
进一步地,所述通过主机覆盖网络获取源虚拟端口信息包括:
通过预设应用程序接口获取所述组播组的成员信息和IP地址;
根据所述成员信息和所述IP地址创建所述组播组。
进一步地,所述虚拟交换机根据所述目的接口信息、所述报文信息和所述组播组的IP地址生成数据面流表,按照所述数据面流表转发所述报文信息包括:
通过所述源虚拟端口位置信息判断所述源虚拟端口是本地接口还是远端接口;
若所述源虚拟端口为本地接口,则将所述源虚拟端口位置信息设置为本地接口信息,所述虚拟交换机根据所述目的接口信息、所述报文信息和所述本地接口信息生成数据面流表,按照所述数据面流表将所述报文信息转发至所述对端虚拟端口;
若所述源虚拟端口为远端接口,则获取本地vxlan tunnel信息,通过所述本地vxlan tunnel信息将所述报文信息发往对端vtep,并通过所述对端vtep剥离所述报文信息的头部后转发到所述对端虚拟端口。
进一步地,所述虚拟交换机根据所述目的接口信息、所述报文信息和所述组播组的IP地址生成数据面流表,按照所述数据面流表转发所述报文信息之前,还包括:
判断所述源虚拟端口是否为未配置过的组播组;
若所述组播组为未配置过的组播组,所述虚拟交换机直接将所述源虚拟端口的所述报文信息丢弃。
进一步地,所述SDN控制器包括全局控制器和本地控制器,所述组播组包括全局组播位置信息和本区域组播位置信息,所述通过主机覆盖网络获取源虚拟端口信息,其中,所述源虚拟端口信息包括组播组、对端虚拟端口位置信息和报文信息,所述对端虚拟端口位置信息包组播组的IP地址和成员信息之前,还包括:
通过所述全局控制器获取并调用所述全局组播位置信息,通过所述本地控制器获取并调用所述本区域组播位置信息。
进一步地,所述虚拟交换机根据所述目的接口信息、所述报文信息和所述组播组的IP地址生成数据面流表,按照所述数据面流表转发所述报文信息之后,还包括:
判断所述对端虚拟端口位置信息是否发生迁移;
若是,则通过编排器采集第二对端虚拟端口位置信息,并将所述第二对端虚拟端口位置信息发送至物理主机服务器,所述第二对端虚拟端口位置信息为迁移后的对端虚拟端口位置信息。
进一步地,所述虚拟交换机根据所述目的接口信息、所述报文信息和所述组播组的IP地址生成数据面流表,按照所述数据面流表转发所述报文信息之后,还包括:
判断所述对端虚拟端口位置信息是否处于浮动状态;
若是,则下发预设地址解析协议提取地址对应关系,根据所述地址对应关系查询实际映射,并将所述映射发送至所述虚拟交换机。
本发明实施例公开了一种基于SDN控制器在主机覆盖网络的组播系统,所述主机覆盖网络包括隧道和位于所述隧道两端的源虚拟端口和对端虚拟端口,包括:
信息获取模块,用于通过主机覆盖网络获取源虚拟端口信息,其中,所述源虚拟端口信息包括组播组、对端虚拟端口位置信息和报文信息,所述对端虚拟端口位置信息包括组播组的IP地址和成员信息;
信息解析模块,用于根据所述成员信息解析出目的接口信息;
报文转发模块,用于虚拟交换机根据所述目的接口信息、所述报文信息和所述组播组的IP地址生成数据面流表,按照所述数据面流表转发所述报文信息。
本发明实施例公开了一种电子设备,包括处理器、存储器及存储在所述存储器上并能够在所述处理器上运行的计算机程序,所述计算机程序被所述处理器执行时实现如上述的基于SDN控制器在主机覆盖网络的组播方法的步骤。
本发明实施例公开了一种计算机可读存储介质,所述计算机可读存储介质上存储计算机程序,所述计算机程序被处理器执行时实现如上述的基于SDN控制器在主机覆盖网络的组播方法的步骤。
本发明实施例包括以下优点:采用SDN控制器集中控制覆盖网络的组播组信息,根据控制器对全网拓扑的了解生成组播流量规则,并下发到主机上的分布式虚拟路由器执行,在数据面流表投递的时候,根据获取到的接口信息直接将报文信息发往组播组成员所在的接口,使用精准地投递方式,较好的抑制了组播报文在二层的泛洪问题,解决了网路负担较重的现象。
附图说明
图1是本发明的基于SDN控制器在主机覆盖网络的组播方法一实施例的步骤流程图;
图2是本发明的基于SDN控制器在主机覆盖网络的组播方法另一实施例的步骤流程图;
图3是本发明的基于SDN控制器在主机覆盖网络的组播方法另一实施例的步骤流程图;
图4是本发明的一种基于SDN控制器在主机覆盖网络的组播系统实施例的结构框图;
图5是本发明的一种基于SDN控制器在主机覆盖网络的组播系统实施例的结构框图;
图6是本发明的一种基于SDN控制器在主机覆盖网络的组播系统实施例的结构框图。
具体实施方式
为使本发明的上述目的、特征和优点能够更加明显易懂,下面结合附图和具体实施方式对本发明作进一步详细的说明。
本发明实施例的核心构思之一在于,提供了一种基于SDN控制器在主机覆盖网络的组播方法及系统,主机覆盖网络包括隧道、位于隧道两端的源虚拟端口和对端虚拟端口,通过主机覆盖网络获取源虚拟端口信息,其中,源虚拟端口信息包括组播组、对端虚拟端口位置信息和报文信息,对端虚拟端口位置信息包括组播组的IP地址和成员信息;根据成员信息解析出目的接口信息;虚拟交换机根据目的接口信息、报文信息和组播组的IP地址生成数据面流表,按照数据面流表转发报文信息。采用SDN控制器集中控制覆盖网络的组播组信息,在数据面流表投递的时候,直接发往组播组成员所在的虚拟网口(vport),使用精准地投递方式,较好的抑制了组播报文在二层的泛洪问题,解决了网路负担较重的现象。
参照图1-3,示出了本发明的一种基于SDN控制器在主机覆盖网络的组播方法实施例的步骤流程图,主机覆盖网络包括隧道和位于隧道两端的源虚拟端口和对端虚拟端口,具体可以包括如下步骤:
S100,通过主机覆盖网络获取源虚拟端口信息,其中,源虚拟端口信息包括组播组、对端虚拟端口位置信息和报文信息,对端虚拟端口位置信息包括组播组的IP地址和成员信息;
S200,根据成员信息解析出目的接口信息;
S300,虚拟交换机(vSwitch)根据目的接口信息、报文信息和组播组的IP地址生成数据面流表,按照数据面流表转发报文信息。
采用SDN控制器集中控制覆盖网络的组播组信息,在数据面流表投递的时候,直接发往组播组成员所在的接口,使用精准地投递方式,较好的抑制了组播报文在二层的泛洪问题,解决了网路负担较重的现象。
如上述步骤S100所述,NVE(Network Virtrualization Edge,网络虚拟边缘节点)是实现网络虚拟化的功能实体,VM里的报文经过网络虚拟边缘节点封装后,网络虚拟边缘节点之间就可以在基于L3的网络基础上建立起L2虚拟网络。网络设备实体以及服务器实体上的虚拟交换机(vSwitch)都可以作为网络虚拟边缘节点。VTEP为VXLAN隧道的端点,封装在网络虚拟边缘节点中,用于VXLAN报文的封装和解封装。VTEP与物理网络相连,分配的地址为物理网络IP地址。通过主机覆盖网络获取源虚拟端口信息,源虚拟端口信息包括组播组、对端虚拟端口位置信息和报文信息,对端虚拟端口位置信息包括组播组的IP地址和成员信息。其中主要包括SDN控制器(controller)、下层(Underlay)网络设备和物理主机,SDN控制器负责虚拟化网络的编排功能,能获得虚机虚拟网口(vport)的所有信息,上述接口的信息包括但不限于:IP(Internet Protocol,网际互连协议)、MAC(Media Access Control,介质访问控制)、vtep info(端点域名),并负责把虚拟网络域的全量的接口信息下发给虚拟网络包含的主机。下层网络设备主要负责下层网络的IP互通,并采用传统的CLOS架构部署。物理主机用于安装主机覆盖相关软承载虚机及虚机网络,软件实现虚拟交换机、vRouter及vtep功能。主机vtep之间是full mesh的vxlan(Virtual eXtensible LAN,可扩展虚拟局域网)网络。
如上述步骤S200所述,根据成员信息解析出目的接口信息,能够直接将报文信息传送至对端虚拟端口,避免出现报文在二层的泛洪,减轻网络负担。
如上述步骤S300所述,虚拟交换机(vSwitch)根据目的接口信息、报文信息和组播组的IP地址生成数据面流表,按照数据面流表转发报文信息。虚拟交换机根据预设规则将上述报文进行头端复制,进行转发。上述转发方式成本低,不依赖于网络中路由器对组播的支持,同时不需要用户在应用层面做适配或者安装软件。
在本实施例中,通过主机覆盖网络获取源虚拟端口信息包括:
S110,通过预设应用程序接口获取组播组的成员信息和IP地址;
S120,根据成员信息和IP地址创建组播组。
如上述步骤所述,通过用户创建组播组并自定义组播成员,避免在主机覆盖网络上运行组播路由协议,上述组播组创建主要是租户通过接口创建组播组,并指定IP地址,然后租户将需要的虚拟网口IP加入上述组播组。当组播组变动或成员变动时,租户可自行删除或增加组播组或组播组成员,上述租户的创建端口包括但不限于portal和API(Application Programming Interface,应用程序接口),Portal是作为网关服务于因特网的一种WEB站点。采用简单的组播组管理机制,灵活创建、加入和离开组播组的方式,避免了在覆盖网络使用复杂的组播管理和路由协议,给用户提供了便利的组播管理方式。
在本实施例中,虚拟交换机(vSwitch)根据目的接口信息、报文信息和组播组的IP地址生成数据面流表,按照数据面流表转发报文信息的步骤S300,包括:
S310,通过源虚拟端口位置信息判断源虚拟端口(vport)是本地接口还是远端接口;
S320,若源虚拟端口为本地接口,则将源虚拟端口位置信息设置为本地接口信息,虚拟交换机(vSwitch)根据目的接口信息、报文信息和本地接口信息生成数据面流表,按照数据面流表将报文信息转发至对端虚拟端口;
S330,若源虚拟端口为远端接口,则获取本地vxlan tunnel信息,通过本地vxlantunnel信息将报文信息发往对端vtep,并通过对端vtep剥离报文信息的头部后转发到对端虚拟端口。
如上述步骤所述,物理主机服务器遍历所有成员,根据其IP地址找到成员的接口位置信息,并判断上述成员的接口是本地接口还是远端接口,若上述成员的接口为本地接口,上述组播成员与组播源在同一主机,则虚拟交换机直接将报文进行头端复制,使虚拟交换机按照目的接口信息进行转发。若上述成员的接口是远端接口,则获取本地vxlantunnel信息,将上述报文进行复制后,通过vxlan tunnel接口将报文转发至目的接口信息。上述目的接口信息为对端vtep,剥离vxlan报文头部之后转发至对应的接口上。
在本实施例中,虚拟交换机(vSwitch)根据目的接口信息、报文信息和组播组的IP地址生成数据面流表,按照数据面流表转发报文信息的步骤S300之前,还包括:
判断源虚拟端口是否为未配置过的组播组;
若组播组为未配置过的组播组,虚拟交换机(vSwitch)直接将源虚拟端口的报文信息丢弃。
如上述步骤所述,当上述组播组为未配置时,直接将所述源虚拟端口的报文丢弃,从而有效的减少了网络对于未知报文处理时的资源占用,减少不必要未知报文对网络的冲击,有效的减轻网络的负担。
在本实施例中,SDN控制器(controller)包括全局控制器(global controller)和本地控制器(local controller),组播组包括全局组播位置信息和本区域组播位置信息,通过主机覆盖网络获取源虚拟端口信息,源虚拟端口信息包括组播组、对端虚拟端口位置信息和报文信息,对端虚拟端口位置信息包组播组的IP地址和成员信息之前,还包括:
通过全局控制器获取并调用全局组播位置信息,通过本地控制器获取并调用本区域组播位置信息。
如上述步骤所述,采用SDN控制器集中控制覆盖网络的组播组信息,依赖SDN控制器对全网拓扑的了解生,成组播流量的规则并下发到主机上的分布式虚拟路由器执行。对于网络规模比较大的情况,可以采用分层的SDN控制器来处理,使用全局控制器维护全局组播位置信息,使用本地控制器维护本区域位置信息。
在本实施例中,虚拟交换机(vSwitch)根据目的接口信息、报文信息和组播组的IP地址生成数据面流表,按照数据面流表转发报文信息之后,还包括:
判断对端虚拟端口位置信息是否发生迁移;
若是,则通过编排器采集第二对端虚拟端口位置信息,并将第二对端虚拟端口位置信息发送至物理主机服务器,第二对端虚拟端口位置信息为迁移后的对端虚拟端口位置信息。
如上述步骤所述,对于虚机迁移的情况,SDN控制器通过与编排器交互,获得迁移后的IP地址到接口的对应信息,并下发给物理主机服务器。能够在VM迁移的情况下,有效保证虚机IP地址和接口信息的更新。
在本实施例中,虚拟交换机(vSwitch)根据目的接口信息、报文信息和组播组的IP地址生成数据面流表,按照数据面流表转发报文信息的步骤之后,还包括:
判断对端虚拟端口位置信息是否处于浮动状态;
若是,则下发预设地址解析协议提取地址对应关系,根据地址对应关系查询实际映射,并将映射发送至虚拟交换机。
如上述步骤所述,对于浮动IP的情况,则会预先下发处理免费ARP(AddressResolution Protocol,地址解析协议)的规则给主机,所有免费地址解析协议报文都会被主机的虚拟交换机截获,提取IP到mac的对应关系并反向通知SDN控制器,SDN控制器根据已经掌握的位置信息来找到真实的IP到接口的映射,然后再下发给虚拟网络内的主机,以完成更新。
通过本方法在云网络基础架构层面解决了覆盖网络的组播支持问题。通过头端复制技术,在流表投递的时候,只会发往组播组成员所在的接口,比较好的抑制了组播报文在二层的泛洪,不会造成很大的网络负担。本方法使用简单组播组创建、加入和离开机制,避免了在覆盖网络使用复杂的组播管理和路由协议,给用户提供了比较便利的组播管理方式。通过在主机侧截获免费地址解析协议并反向通知控制器,可以有效更新组播成员接口位置信息,以支持一些IP迁移的用户故事。方法可全部软件实现,成本较低,不依赖网络中的路由器硬件对组播的支持,同时不需要用户在应用层面做适配或者安装软件proxy。
需要说明的是,对于方法实施例,为了简单描述,故将其都表述为一系列的动作组合,但是本领域技术人员应该知悉,本发明实施例并不受所描述的动作顺序的限制,因为依据本发明实施例,某些步骤可以采用其他顺序或者同时进行。其次,本领域技术人员也应该知悉,说明书中所描述的实施例均属于优选实施例,所涉及的动作并不一定是本发明实施例所必须的。
参照图4-6,示出了本发明的一种基于SDN控制器在主机覆盖网络的组播系统实施例的结构框图,主机覆盖网络包括隧道和位于隧道两端的源虚拟端口和对端虚拟端口,通过将数据从源虚拟端口转发至对端虚拟端口,具体可以包括如下模块:
信息获取模块100,用于通过主机覆盖网络获取源虚拟端口信息,其中,源虚拟端口信息包括组播组、对端虚拟端口位置信息和报文信息,对端虚拟端口位置信息包括组播组的IP地址和成员信息;
信息解析模块200,用于根据成员信息解析出目的接口信息;
报文转发模块300,用于虚拟交换机(vSwitch)根据目的接口信息、报文信息和组播组IP地址生成数据面流表,按照数据面流表转发报文信息。
在本实施例中,信息获取模块100包括:
信息获取子模块110,用于通过预设应用程序接口获取组播组的成员信息和IP地址;
组播组创建子模块120,用于根据成员信息和IP地址创建组播组。
在本实施例中,报文转发模块300包括:
端口判断子模块310,用于通过源虚拟端口位置信息判断源虚拟端口是本地接口还是远端接口;
本地端口子模块320,用于若源虚拟端口为本地接口,则将源虚拟端口位置信息设置为本地接口信息,虚拟交换机(vSwitch)根据目的接口信息、报文信息和本地接口信息生成数据面流表,按照数据面流表将报文信息转发至对端虚拟端口;
远端端口子模块330,用于若源虚拟端口为远端接口,则获取本地vxlan tunnel信息,通过vxlan tunnel将报文信息发往对端vtep,并通过对端vtep剥离报文信息的头部后转发到对端虚拟端口。
在本实施例中,还包括:
第一判断模块,用于判断源虚拟端口是否为未配置过的组播组;
报文丢弃模块,用于若组播组为未配置过的组播组,虚拟交换机(vSwitch)直接将源虚拟端口的报文信息丢弃。
在本实施例中,SDN控制器包括全局控制器和本地控制器,组播组包括全局组播位置信息和本区域组播位置信息,还包括:
分层处理模块,用于通过全局控制器获取并调用全局组播位置信息,通过本地控制器获取并调用本区域组播位置信息。
在本实施例中,还包括:
迁移判断模块,用于判断对端虚拟端口位置信息是否发生迁移;
信息更新模块,用于若对端虚拟端口位置信息发生迁移,则通过编排器采集第二对端虚拟端口位置信息,并将第二对端虚拟端口位置信息发送至物理主机服务器,第二对端虚拟端口位置信息为迁移后的对端虚拟端口位置信息。
在本实施例中,还包括:
浮动判断模块,用于判断对端虚拟端口位置信息是否处于浮动状态;
地址映射模块,用于若对端虚拟端口位置信息处于浮动状态,则下发预设地址解析协议提取其地址对应关系,根据地址对应关系查询实际映射,并将映射发送至虚拟交换机。
对于装置实施例而言,由于其与方法实施例基本相似,所以描述的比较简单,相关之处参见方法实施例的部分说明即可。
本说明书中的各个实施例均采用递进的方式描述,每个实施例重点说明的都是与其他实施例的不同之处,各个实施例之间相同相似的部分互相参见即可。
本发明实施例公开了一种电子设备,包括处理器、存储器及存储在存储器上并能够在处理器上运行的计算机程序,计算机程序被处理器执行时实现如上述的基于SDN控制器在主机覆盖网络的组播方法的步骤。
本发明实施例公开了一种计算机可读存储介质,计算机可读存储介质上存储计算机程序,计算机程序被处理器执行时实现如上述的基于SDN控制器在主机覆盖网络的组播方法的步骤。
本领域内的技术人员应明白,本发明实施例的实施例可提供为方法、装置、或计算机程序产品。因此,本发明实施例可采用完全硬件实施例、完全软件实施例、或结合软件和硬件方面的实施例的形式。而且,本发明实施例可采用在一个或多个其中包含有计算机可用程序代码的计算机可用存储介质(包括但不限于磁盘存储器、CD-ROM、光学存储器等)上实施的计算机程序产品的形式。
本发明实施例是参照根据本发明实施例的方法、终端设备(系统)、和计算机程序产品的流程图和/或方框图来描述的。应理解可由计算机程序指令实现流程图和/或方框图中的每一流程和/或方框、以及流程图和/或方框图中的流程和/或方框的结合。可提供这些计算机程序指令到通用计算机、专用计算机、嵌入式处理机或其他可编程数据处理终端设备的处理器以产生一个机器,使得通过计算机或其他可编程数据处理终端设备的处理器执行的指令产生用于实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能的装置。
这些计算机程序指令也可存储在能引导计算机或其他可编程数据处理终端设备以特定方式工作的计算机可读存储器中,使得存储在该计算机可读存储器中的指令产生包括指令装置的制造品,该指令装置实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能。
这些计算机程序指令也可装载到计算机或其他可编程数据处理终端设备上,使得在计算机或其他可编程终端设备上执行一系列操作步骤以产生计算机实现的处理,从而在计算机或其他可编程终端设备上执行的指令提供用于实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能的步骤。
尽管已描述了本发明实施例的优选实施例,但本领域内的技术人员一旦得知了基本创造性概念,则可对这些实施例做出另外的变更和修改。所以,所附权利要求意欲解释为包括优选实施例以及落入本发明实施例范围的所有变更和修改。
最后,还需要说明的是,在本文中,诸如第一和第二等之类的关系术语仅仅用来将一个实体或者操作与另一个实体或操作区分开来,而不一定要求或者暗示这些实体或操作之间存在任何这种实际的关系或者顺序。而且,术语“包括”、“包含”或者其任何其他变体意在涵盖非排他性的包含,从而使得包括一系列要素的过程、方法、物品或者终端设备不仅包括那些要素,而且还包括没有明确列出的其他要素,或者是还包括为这种过程、方法、物品或者终端设备所固有的要素。在没有更多限制的情况下,由语句“包括一个……”限定的要素,并不排除在包括所述要素的过程、方法、物品或者终端设备中还存在另外的相同要素。
以上对本发明所提供的一种一种基于SDN控制器在主机覆盖网络的组播方法和一种基于SDN控制器在主机覆盖网络的组播系统,进行了详细介绍,本文中应用了具体个例对本发明的原理及实施方式进行了阐述,以上实施例的说明只是用于帮助理解本发明的方法及其核心思想;同时,对于本领域的一般技术人员,依据本发明的思想,在具体实施方式及应用范围上均会有改变之处,综上所述,本说明书内容不应理解为对本发明的限制。

Claims (9)

1.一种基于SDN控制器的组播方法,其特征在于,应用于主机覆盖网络中,所述主机覆盖网络包括隧道、位于所述隧道两端的源虚拟端口和对端虚拟端口,包括步骤:
通过所述主机覆盖网络获取源虚拟端口信息,其中,所述源虚拟端口信息包括组播组、对端虚拟端口位置信息和报文信息,所述对端虚拟端口位置信息包括组播组的IP地址和成员信息;通过预设应用程序接口获取所述组播组的成员信息和IP地址;根据所述成员信息和所述IP地址创建所述组播组,具体地,通过创建所述组播组并自定义组播成员,通过接口创建所述组播组,并指定IP地址,并将需要的虚拟网口IP加入所述组播组;
根据所述成员信息解析出目的接口信息;
虚拟交换机根据所述目的接口信息、所述报文信息和所述组播组的IP地址生成数据面流表,按照所述数据面流表转发所述报文信息。
2.根据权利要求1所述的方法,其特征在于,所述虚拟交换机根据所述目的接口信息、所述报文信息和所述组播组的IP地址生成数据面流表,按照所述数据面流表转发所述报文信息包括:
通过所述源虚拟端口位置信息判断所述源虚拟端口是本地接口还是远端接口;
若所述源虚拟端口为本地接口,则将所述源虚拟端口位置信息设置为本地接口信息,所述虚拟交换机根据所述目的接口信息、所述报文信息和所述本地接口信息生成数据面流表,按照所述数据面流表将所述报文信息转发至所述对端虚拟端口;
若所述源虚拟端口为远端接口,则获取本地vxlan tunnel信息,通过所述本地vxlantunnel信息将所述报文信息发往对端vtep,并通过所述对端vtep剥离所述报文信息的头部后转发到所述对端虚拟端口。
3.根据权利要求1所述的方法,其特征在于,所述虚拟交换机根据所述目的接口信息、所述报文信息和所述组播组的IP地址生成数据面流表,按照所述数据面流表转发所述报文信息之前,还包括:
判断所述源虚拟端口是否为未配置过的组播组;
若所述组播组为未配置过的组播组,所述虚拟交换机直接将所述源虚拟端口的所述报文信息丢弃。
4.根据权利要求1所述的方法,其特征在于,所述SDN控制器包括全局控制器和本地控制器,所述组播组包括全局组播位置信息和本区域组播位置信息,所述通过主机覆盖网络获取源虚拟端口信息,其中,所述源虚拟端口信息包括组播组、对端虚拟端口位置信息和报文信息,所述对端虚拟端口位置信息包组播组的IP地址和成员信息之前,还包括:
通过所述全局控制器获取并调用所述全局组播位置信息,通过所述本地控制器获取并调用所述本区域组播位置信息。
5.根据权利要求1所述的方法,其特征在于,所述虚拟交换机根据所述目的接口信息、所述报文信息和所述组播组的IP地址生成数据面流表,按照所述数据面流表转发所述报文信息之后,还包括:
判断所述对端虚拟端口位置信息是否发生迁移;
若是,则通过编排器采集第二对端虚拟端口位置信息,并将所述第二对端虚拟端口位置信息发送至物理主机服务器,所述第二对端虚拟端口位置信息为迁移后的对端虚拟端口位置信息。
6.根据权利要求1所述的方法,其特征在于,所述虚拟交换机根据所述目的接口信息、所述报文信息和所述组播组的IP地址生成数据面流表,按照所述数据面流表转发所述报文信息之后,还包括:
判断所述对端虚拟端口位置信息是否处于浮动状态;
若是,则下发预设地址解析协议提取地址对应关系,根据所述地址对应关系查询实际映射,并将所述映射发送至所述虚拟交换机。
7.一种基于SDN控制器在主机覆盖网络的组播系统,其特征在于,所述主机覆盖网络包括隧道和位于所述隧道两端的源虚拟端口和对端虚拟端口,包括:
信息获取模块,用于通过主机覆盖网络获取源虚拟端口信息,其中,所述源虚拟端口信息包括组播组、对端虚拟端口位置信息和报文信息,所述对端虚拟端口位置信息包括组播组的IP地址和成员信息;通过预设应用程序接口获取所述组播组的成员信息和IP地址;根据所述成员信息和所述IP地址创建所述组播组,具体地,通过创建所述组播组并自定义组播成员,通过接口创建所述组播组,并指定IP地址,并将需要的虚拟网口IP加入所述组播组;
信息解析模块,用于根据所述成员信息解析出目的接口信息;
报文转发模块,用于虚拟交换机根据所述目的接口信息、所述报文信息和所述组播组的IP地址生成数据面流表,按照所述数据面流表转发所述报文信息。
8.电子设备,其特征在于,包括处理器、存储器及存储在所述存储器上并能够在所述处理器上运行的计算机程序,所述计算机程序被所述处理器执行时实现如权利要求1至6中任一项所述的基于SDN控制器的组播方法的步骤。
9.计算机可读存储介质,其特征在于,所述计算机可读存储介质上存储计算机程序,所述计算机程序被处理器执行时实现如权利要求1至6中任一项所述的基于SDN控制器的组播方法的步骤。
CN202010364674.5A 2020-04-30 2020-04-30 基于sdn控制器在主机覆盖网络的组播方法 Active CN111585900B (zh)

Priority Applications (2)

Application Number Priority Date Filing Date Title
CN202010364674.5A CN111585900B (zh) 2020-04-30 2020-04-30 基于sdn控制器在主机覆盖网络的组播方法
PCT/CN2020/118903 WO2021218026A1 (zh) 2020-04-30 2020-09-29 基于sdn控制器在主机覆盖网络的组播方法、系统、设备及介质

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN202010364674.5A CN111585900B (zh) 2020-04-30 2020-04-30 基于sdn控制器在主机覆盖网络的组播方法

Publications (2)

Publication Number Publication Date
CN111585900A CN111585900A (zh) 2020-08-25
CN111585900B true CN111585900B (zh) 2022-11-18

Family

ID=72124614

Family Applications (1)

Application Number Title Priority Date Filing Date
CN202010364674.5A Active CN111585900B (zh) 2020-04-30 2020-04-30 基于sdn控制器在主机覆盖网络的组播方法

Country Status (2)

Country Link
CN (1) CN111585900B (zh)
WO (1) WO2021218026A1 (zh)

Families Citing this family (8)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN111585900B (zh) * 2020-04-30 2022-11-18 平安科技(深圳)有限公司 基于sdn控制器在主机覆盖网络的组播方法
CN113347031B (zh) * 2021-05-27 2022-07-12 中国电子科技集团公司第七研究所 一种基于组播方式的sdn虚网构建系统及构建方法
CN114024921B (zh) * 2021-10-14 2024-05-28 郑州浪潮数据技术有限公司 一种隧道协同方法、装置、设备及可读存储介质
CN113872847B (zh) * 2021-11-18 2023-05-30 浪潮思科网络科技有限公司 一种基于vxlan网络的报文转发方法、设备及介质
CN114650471B (zh) * 2022-03-28 2023-12-26 洛阳萃泽信息科技有限公司 一种数控机床采集系统、集中采集模块及机床数据采集方法
CN115242733B (zh) * 2022-06-24 2023-10-20 北京百度网讯科技有限公司 报文组播方法、组播网关、电子设备及存储介质
CN115297012B (zh) * 2022-08-03 2024-02-06 重庆奥普泰通信技术有限公司 Sdn控制器的离线测试方法、装置、控制器及介质
CN115941594A (zh) * 2022-09-07 2023-04-07 成都西加云杉科技有限公司 基于sdn的组播报文抑制方法、装置、设备及存储介质

Citations (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN101364889A (zh) * 2008-09-24 2009-02-11 中兴通讯股份有限公司 一种快速接入组播用户的方法
CN105262667A (zh) * 2015-09-17 2016-01-20 杭州数梦工场科技有限公司 Overlay网络中控制组播传输的方法、装置
CN107612809A (zh) * 2017-10-31 2018-01-19 新华三技术有限公司 一种组播表项同步方法以及设备
WO2018177353A1 (zh) * 2017-03-29 2018-10-04 中兴通讯股份有限公司 组播数据的转发方法和装置
CN109257190A (zh) * 2018-08-03 2019-01-22 锐捷网络股份有限公司 一种基于sdn的组播处理方法、控制器、交换机及系统

Family Cites Families (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US10225094B2 (en) * 2012-05-29 2019-03-05 Futurewei Technologies, Inc. SDN facilitated multicast in data center
CN107204867B (zh) * 2016-03-18 2020-03-24 中兴通讯股份有限公司 一种信息传输方法、装置和系统
CN106209622A (zh) * 2016-06-23 2016-12-07 广州海格通信集团股份有限公司 一种基于sdn的组播方法
CN109379292A (zh) * 2018-10-09 2019-02-22 郑州云海信息技术有限公司 一种组播方法、虚拟交换机、sdn控制器及存储介质
CN111585900B (zh) * 2020-04-30 2022-11-18 平安科技(深圳)有限公司 基于sdn控制器在主机覆盖网络的组播方法

Patent Citations (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN101364889A (zh) * 2008-09-24 2009-02-11 中兴通讯股份有限公司 一种快速接入组播用户的方法
CN105262667A (zh) * 2015-09-17 2016-01-20 杭州数梦工场科技有限公司 Overlay网络中控制组播传输的方法、装置
WO2018177353A1 (zh) * 2017-03-29 2018-10-04 中兴通讯股份有限公司 组播数据的转发方法和装置
CN107612809A (zh) * 2017-10-31 2018-01-19 新华三技术有限公司 一种组播表项同步方法以及设备
CN109257190A (zh) * 2018-08-03 2019-01-22 锐捷网络股份有限公司 一种基于sdn的组播处理方法、控制器、交换机及系统

Also Published As

Publication number Publication date
CN111585900A (zh) 2020-08-25
WO2021218026A1 (zh) 2021-11-04

Similar Documents

Publication Publication Date Title
CN111585900B (zh) 基于sdn控制器在主机覆盖网络的组播方法
US10565001B2 (en) Distributed virtual network controller
CN111371706B (zh) 跨物理和虚拟化工作负载使用虚拟化覆盖的具有多个协议的云网络
EP2930892B1 (en) Physical path determination for virtual network packet flows
CN112398676B (zh) 多租户环境中服务接入端点的基于供应商无关简档的建模
CN106452857B (zh) 生成配置信息的方法和网络控制单元
CN112583710B (zh) 软件定义网络中的辅助复制
CN106850459B (zh) 一种实现虚拟网络负载均衡的方法及装置
US10999195B1 (en) Multicast VPN support in data centers using edge replication tree
US10379890B1 (en) Synchronized cache of an operational state of distributed software system
WO2021098727A1 (zh) 网络部署的方法及系统
CN113254148A (zh) 一种虚拟机的迁移方法及云管理平台
Jain OpenFlow, software defined networking (SDN) and network function virtualization (NFV)
Giatsios et al. Design and evaluation of a hierarchical SDN control plane for 5G transport networks
JP5580766B2 (ja) サーバ装置、パケット伝送システム、パケット伝送方法及びプログラム
Lim et al. Design and implementation of hardware accelerated VTEP in datacenter networks
CN117880097A (zh) 云租户eip迁移方法、装置、计算机设备及存储介质

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