CN109561057A - 一种内容分发网络实体业务处理方法、装置及系统 - Google Patents
一种内容分发网络实体业务处理方法、装置及系统 Download PDFInfo
- Publication number
- CN109561057A CN109561057A CN201710889657.1A CN201710889657A CN109561057A CN 109561057 A CN109561057 A CN 109561057A CN 201710889657 A CN201710889657 A CN 201710889657A CN 109561057 A CN109561057 A CN 109561057A
- Authority
- CN
- China
- Prior art keywords
- content distribution
- distribution network
- forwarding
- network entity
- information
- 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.)
- Pending
Links
- 238000003672 processing method Methods 0.000 title claims description 31
- 238000000034 method Methods 0.000 claims abstract description 28
- 230000002159 abnormal effect Effects 0.000 claims description 64
- 238000007726 management method Methods 0.000 claims description 25
- 238000004590 computer program Methods 0.000 claims description 12
- 238000012545 processing Methods 0.000 abstract description 7
- 230000004044 response Effects 0.000 description 15
- 206010033799 Paralysis Diseases 0.000 description 5
- 238000010586 diagram Methods 0.000 description 5
- 230000003993 interaction Effects 0.000 description 5
- 230000008569 process Effects 0.000 description 5
- 230000009471 action Effects 0.000 description 3
- 238000004891 communication Methods 0.000 description 3
- 230000008878 coupling Effects 0.000 description 3
- 238000010168 coupling process Methods 0.000 description 3
- 238000005859 coupling reaction Methods 0.000 description 3
- 238000005516 engineering process Methods 0.000 description 3
- 230000005540 biological transmission Effects 0.000 description 2
- 230000000977 initiatory effect Effects 0.000 description 2
- 238000011084 recovery Methods 0.000 description 2
- 238000012546 transfer Methods 0.000 description 2
- 101100339496 Caenorhabditis elegans hop-1 gene Proteins 0.000 description 1
- 230000009286 beneficial effect Effects 0.000 description 1
- 238000011161 development Methods 0.000 description 1
- 230000006870 function Effects 0.000 description 1
- 230000002452 interceptive effect Effects 0.000 description 1
- 238000010295 mobile communication Methods 0.000 description 1
- 238000012986 modification Methods 0.000 description 1
- 230000004048 modification Effects 0.000 description 1
- 230000003287 optical effect Effects 0.000 description 1
- 230000002093 peripheral effect Effects 0.000 description 1
- 238000010187 selection method Methods 0.000 description 1
- 230000001360 synchronised effect Effects 0.000 description 1
Classifications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L65/00—Network arrangements, protocols or services for supporting real-time applications in data packet communication
- H04L65/80—Responding to QoS
Landscapes
- Engineering & Computer Science (AREA)
- Multimedia (AREA)
- Computer Networks & Wireless Communication (AREA)
- Signal Processing (AREA)
- Data Exchanges In Wide-Area Networks (AREA)
Abstract
本发明实施例提供了一种CDN业务处理方法、装置及系统,CDN业务处理方法包括:接收用户报文,根据所述用户报文和预存的内容分发网络实体的转发链的信息,得到有效的内容分发网络实体的转发链的信息;将所述有效的内容分发网络实体的转发链的信息转发给与所述有效的内容分发网络实体相对应的软件定义网络转发设备,由所述软件定义网络转发设备将所述用户报文转发给所述有效的内容分发网络实体,这样可解决在用户接入内容分发网络实体时由于多次网络七层重定向导致的服务延迟问题,同时解决传统内容分发网络由于全局负载均衡服务器而引发的单点故障问题。
Description
技术领域
本发明涉及通信技术领域,特别涉及一种内容分发网络实体业务处理方法、装置及系统。
背景技术
CDN(Content Delivery Network,内容分发网络)作为一种有效的传输网络,被广泛应用于IPTV(Internet Protocol television,网络视讯)网络电视、OTT(Over The Top,互联网电视)互联网电信业务系统,现在已经在世界各地广泛部署。随着固网宽带速率不断提升、移动宽带迅猛发展、4K视频技术的普及,基于运营商专有的网络IPTV用户,以及基于互联网的OTT视频用户也越来越多,并发的大量增长对CDN的设备和技术都提出了更多更高的要求:用户期望获取服务的延迟越来越小,网络系统要能够快速响应用户服务;系统要稳定可靠,网络中断,或者服务器设备异常的时候,能够稳定持续地向用户提供服务,具备容灾能力;
为了能够实现CDN节点的容灾,传统的CDN系统包含调度节点以及多个CDN节点,其中,调度节点部署在网络的中心,为用户提供全局负载均衡服务,多个CDN节点部署在网络的边缘。用户终端在接入CDN系统的时候,一般是通过7层协议比如HTTP(Hyper TextTransfer Protocol,超文本传输协议)、RTSP(Real Time Streaming Protocol,实时流传输协议),先向CDN系统的调度节点的GSLB(Global Server Load Balance,全局负载均衡)发起重定向请求,GSLB返回用户网络边缘的CDN节点地址;用户终端再向CDN节点发起服务请求,如果CDN节点状态发生异常,用户终端需要再次向GSLB发起重定向请求。由此可知,现有技术中用户终端为了获得CDN节点的服务,需要向GSLB发起至少一次七层的重定向请求,而从第一次发起重定向请求到服务开始的延迟比较大,影响用户体验。
发明内容
为了解决上述技术问题,本发明实施例提供了一种CDN业务处理方法、装置及系统,可解决在用户接入内容分发网络实体时由于多次网络七层重定向导致的服务延迟问题。
依据本发明实施例的一方面,提供了一种CDN业务处理方法,包括:
接收用户报文,根据所述用户报文和预存的内容分发网络实体的转发链的信息,得到有效的内容分发网络实体所对应的转发链的信息;其中,所述有效的内容分发网络实体是指内容分发网络实体所对应的转发链无异常和/或所述有效的内容分发网络实体的转发链的转发链优先级最高;
将所述有效的内容分发网络实体的转发链的信息转发给与所述有效的内容分发网络实体对应的软件定义网络转发设备,由所述软件定义网络转发设备将所述用户报文转发给所述有效的内容分发网络实体。
可选地,所述根据所述用户报文和预存的内容分发网络实体的转发链的信息,得到有效的内容分发网络实体的转发链的信息,包括:
根据所述用户报文的源IP地址、源端口、目的IP地址和/或目的端口和预存的内容分发网络实体的转发链的信息,确定与所述用户报文的源IP地址、源端口、目的IP地址和/或目的端口对应的一个或多个内容分发网络实体的转发链的信息;
根据确定的一个或多个内容分发网络实体的转发链的信息,以及内容分发网络实体的转发链状态,得到有效的内容分发网络实体的转发链的信息。
可选地,所述多个内容分发网络实体的转发链的信息至少包括:第一内容分发网络实体的转发链的信息和第二内容分发网络实体的转发链的信息;
所述根据确定的多个内容分发网络实体的转发链的信息,以及所有内容分发网络实体的状态,得到有效的内容分发网络实体的转发链的信息,包括:
判断第一内容分发网络实体对应的转发链状态是否为异常;
若所述第一内容分发网络实体所对应的转发链状态不是异常状态,将所述第一内容分发网络实体所对应的转发链信息确定为有效的内容分发网络实体的转发链信息;
若所述第一内容分发网络实体所对应的转发链状态是异常状态,根据所述用户报文匹配得到的第二内容分发网络实体所对应的转发链信息,将所述第二内容分发网络实体所对应的转发链信息确定为有效的内容分发网络实体的转发链信息。
可选地,在根据所述用户报文、预存的内容分发网络实体的转发链的信息,得到有效的内容分发网络实体的转发链的信息的步骤之前,所述方法还包括:
若内容分发网络实体的状态为异常状态时,将处于异常状态的内容分发网络实体的转发链的信息中的转发链优先级置为最低。
可选地,所述根据所述用户报文、预存的内容分发网络实体的转发链的信息,得到有效的内容分发网络实体的转发链的信息,包括:
根据所述用户报文的源IP地址、源端口、目的IP地址和/或目的端口,确定与所述用户报文的源IP地址、源端口、目的IP地址和/或目的端口对应的一个或多个有效的内容分发网络实体;
根据确定的一个或多个有效的内容分发网络实体,以及预存的内容分发网络实体的转发链的信息中转发链优先级,得到有效的内容分发网络实体的转发链的信息,其中,所述有效的内容分发网络实体的转发链的转发链优先级最高。
依据本发明实施例的另一方面,还提供了一种软件定义网络控制器,包括:
匹配子模块,用于接收用户报文,根据所述用户报文和预存的内容分发网络实体的转发链的信息,得到有效的内容分发网络实体所对应的转发链的信息;其中,所述有效的内容分发网络实体是指内容分发网络实体所对应的转发链无异常和/或所述有效的内容分发网络实体的转发链的转发链优先级最高;
转发子模块,用于将所述有效的内容分发网络实体的转发链的信息转发给与所述有效的内容分发网络实体对应的软件定义网络转发设备,由所述软件定义网络转发设备将所述用户报文转发给所述有效的内容分发网络实体。
可选地,所述匹配子模块包括:
第一匹配单元,用于根据所述用户报文源IP地址、源端口、目的IP地址和/或目的端口,以及预存的所有内容分发网络实体的转发链的信息,确定与所述用户报文的源IP地址、源端口、目的IP地址和/或目的端口对应的一个或多个内容分发网络实体的转发链的信息;
第一确定单元,根据确定的一个或多个内容分发网络实体的转发链的信息,以及内容分发网络实体的转发链状态,得到有效的内容分发网络实体的转发链的信息。
可选地,所述第一确定单元包括:
判断子单元,用于判断第一内容分发网络实体对应的转发链状态是否为异常;
第一确定子单元,用于若所述第一内容分发网络实体所对应的转发链状态不是异常状态,将所述第一内容分发网络实体所对应的转发链信息确定为有效的内容分发网络实体的转发链信息;
第二确定子单元,用于若所述第一内容分发网络实体所对应的转发链状态是异常状态,根据所述用户报文匹配得到的第二内容分发网络实体所对应的转发链信息,将所述第二内容分发网络实体所对应的转发链信息确定为有效的内容分发网络实体的转发链信息。
可选地,所述软件定义网络控制器还包括:
调整子模块,用于若内容分发网络实体的状态为异常状态时,将处于异常状态的内容分发网络实体的转发链的信息中的转发链优先级置为最低。
可选地,所述匹配子模块,包括:
第二确定单元,用于根据所述用户报文的源IP地址、源端口、目的IP地址和/或目的端口,确定与所述用户报文的源IP地址、源端口、目的IP地址和/或目的端口对应的一个或多个有效的内容分发网络实体;
第三确定单元,用于根据确定的一个或多个有效的内容分发网络实体,以及预存的内容分发网络实体的转发链的信息中转发链优先级,得到有效的内容分发网络实体的转发链的信息,其中,所述有效的内容分发网络实体的转发链的转发链优先级最高。
依据本发明实施例的又一方面,还提供了一种内容分发网络系统,包括:用于生成内容分发网络实体的转发链的信息的管理模块、一个或至少两个软件定义网络转发设备、一个或至少两个内容分发网络实体以及一个或至少两个如上所述的软件定义网络控制器。
依据本发明实施例的再一方面,还提供了一种软件定义网络控制器,包括:存储器、处理器及存储在存储器上并可在处理器上运行的计算机程序,所述处理器执行所述程序时实现如上所述的CDN业务处理方法中的步骤。
依据本发明实施例的再一方面,还提供了一种计算机可读存储介质,其上存储有计算机程序,该程序被处理器执行时实现如上所述的CDN业务处理方法中的步骤。
本发明的实施例具有如下有益效果:
首先,通过所述软件定义网络控制器根据所述用户报文,得到有效的第一内容分发网络实体所对应的转发链的信息;进而通过所述软件定义网络控制器根据所述有效的内容分发网络实体所对应的转发链的信息,将所述用户报文转发给所述有效的内容分发网络实体。在本发明实施例中,将原先终端与处在网络中心的全局负载均衡服务器的多次七层交互实现的终端接入,改成终端与处在网络边缘的软件定义网络控制器和转发设备在网络的三层进行智能转发,对于用户终端的来说,在网络七层上,和内容分发网络实体之间只有一次交互。这样,所述CDN业务处理方法在用户终端请求CDN服务时,用户终端与CDN节点之间只发起一次应用层的连接,服务响应延迟低,可解决在用户接入内容分发网络实体时由于多次网络七层重定向导致的延迟问题。
其次,通过所述软件定义网络控制器根据所述用户报文匹配得到第一内容分发网络实体所对应的转发链的信息;若所述第一内容分发网络实体的状态是异常状态且第二内容分发网络实体的状态不是异常状态时,通过所述软件定义网络控制器根据所述用户报文匹配得到的第二内容分发网络实体所对应的转发链的信息,将所述第二内容分发网络实体所对应的转发链的信息确定为有效的内容分发网络实体所对应的转发链的信息,这样在CDN实体状态异常的时候,能够实现CDN节点之间用户服务的调度,用户服务不受影响,与传统CDN的采用的GSLB多次重定向方式相比,这种方式没有中心的调度模块,因此没有单点故障的问题,可解决用户终端到调度节点的网络发生故障而导致业务瘫痪的问题。
附图说明
图1为本发明实施例提供的一种基于软件定义网络的内容分发网络系统的示意图;
图2为本发明实施例提供的一种CDN业务处理方法的流程图;
图3为本发明实施例提供的另一种CDN业务处理方法的流程图;
图4为本发明实施例提供的又一种CDN业务处理方法的流程图;
图5为本发明实施例提供的再一种CDN业务处理方法的流程图;
图6为本发明实施例提供的再一种CDN业务处理方法的流程图;
图7为本发明实施例提供的一种软件定义网络控制器的结构示意图;
图8为本发明另一实施例提供的一种软件定义网络控制器的结构示意图。
具体实施方式
为使本发明要解决的技术问题、技术方案和优点更加清楚,下面将结合附图及具体实施例进行详细描述。
本发明的说明书和权利要求书中的术语“第一”、“第二”等是用于区别类似的对象,而不必用于描述特定的顺序或先后次序。应该理解这样使用的数据在适当情况下可以互换,以便这里描述的本发明的实施例例如能够以除了在这里图示或描述的那些以外的顺序实施。
为了解决由于重定向导致的延迟问题以及由于GSLB服务器发生故障或者是用户终端到调度节点的网络发生故障而导致业务瘫痪的技术问题,本发明实施例提供了一种基于软件定义网络的内容分发网络系统,所述内容分发网络系统包含:用于生成内容分发网络实体的转发链的信息的管理模块、一个或至少两个软件定义网络控制器(或称为SDN控制器)、一个或至少两个软件定义网络转发设备(或称为SDN转发设备)、一个或至少两个内容分发网络实体和用户终端。所述内容分发网络实体可为CDN节点。
例如,参见图1,所述内容分发网络系统包含:管理模块、SDN控制器、第一SDN转发设备、第二SDN转发设备、第一CDN节点和第二CDN节点,其中,第一CDN节点和第二CDN节点为2个CDN HTTP(Hyper Text Transfer Protocol,超文本传输协议)流媒体服务节点,使用HTTP协议对用户终端提供服务;所述第一SDN转发设备分别与用户终端和所述第一CDN节点相连,所述第二SDN转发设备与所述第二CDN节点相连。一个用户终端,通过所述第一SDN转发设备接入到网络,使用HTTP协议向CDN节点请求。当用户终端访问第二CDN节点时,第二SDN转发设备的为第一SDN转发设备的下一跳。
其中,所述管理模块主要负责CDN系统的管理、CDN节点状态的收集以及给SDN控制模块下发配置数据等。所述管理模块能够录入CDN的节点和设备信息,设置CDN节点间的依赖关系,且所述管理模块能够将CDN节点的依赖关系编排成转发链的信息,转发链的信息包括:路径ID、用户请求报文转发匹配规则、转发链中各个SDN转发设备的标识和端口信息,将转发链的信息下发给的SDN控制器。
所述SDN控制器摸块主要负责用户报文的转发控制。所述SDN控制器摸块能够接收并且保存管理模块下发的CDN节点以及节点之间的依赖关系;在用户请求服务的时候,所述SDN控制器摸块能够接收SDN转发设备发送的用户数据包;并且所述SDN控制器摸块能够对用户数据包进行解析,根据预定义的规则与用户包进行匹配,得到用户的转发链的信息,然后把转发链的信息会送给SDN转发设备。SDN控制器模块可以是多个和SDN转发设备部署在相同的网络区域,一般一个SDN控制器负责控制一个区域的多个SDN转发设备的报文转发。
所述SDN转发设备为网络接入层以及核心网的设备,主要负责用户报文的转发。一般,所述SDN转发设备有多个,分散在网络各个区域。其中,所述SDN转发设备包含与用户终端相连的转发设备以及与CDN节点相连的转发设备。在网络边缘的转发设备接收用户终端的数据包,在转发用户数据包之前,所述SDN转发设备可向SDN控制器发送转发请求,在SDN控制器返回用户的转发链的信息之后,再将用户的数据包转发给下一个转发设备。下一个转发设备收到用户数据包之后,使用相同的处理的方式进行转发,直到转发给该用户要访问的CDN的节点。SDN转发设备也能够接收与自己相连的CDN节点的数据包,并且将包会送给上一个SDN转发设备,直接响应报文转发到用户终端。
所述CDN节点可提供内容的缓存能力以及内容的服务能力。所述CDN节点可以接受用户服务请求,并返回用户请求的内容,所述CDN节点包含节点内的负载均衡模块、媒体服务器或者缓存服务器。CDN节点和SDN转发设备相连,接受SDN转发设备的用户报文,然后提供CDN内容的服务。
所述用户终端分散在网络边缘。用户终端通过SDN转发设备接入到网络,可以发起到CDN节点的CDN服务请求,请求报文经过一个到多个SDN转发设备转发之后,发送给CDN节点。用户终端与CDN节点建立应用层协议会话,并且通过应用层协议与CDN节点进行交互,从而获取CDN的网络服务。
基于上述的内容分发网络系统,为了解决由于重定向导致的延迟问题,本发明实施例提供了一种CDN业务处理方法,所述CDN业务处理方法适用于软件定义网络控制器。图2为本发明实施例提供的一种CDN业务处理方法的流程图,参见图2,所述方法包括以下步骤:
S201,接收用户报文,根据所述用户报文和预存的内容分发网络实体的转发链的信息,得到有效的内容分发网络实体所对应的转发链的信息;
其中,所述有效的内容分发网络实体是指内容分发网络实体所对应的转发链无异常和/或所述有效的内容分发网络实体的转发链的转发链优先级最高。需要说明的是,内容分发网络实体所对应的转发链无异常是指内容分发网络实体所对应的转发链本身无异常和/或内容分发网络实体的状态无异常。
在本实施例中,内容分发网络实体对应的转发链信息是由管理模块下发的,所述转发链信息用于表示CDN实体和SDN转发设备之间的依赖关系,所述转发链信息包括:转发链的标识(或称为路径ID)、转发链的优先级、用户请求报文转发匹配规则、转发链中各个SDN转发设备的标识和端口信息等。
同时,所述管理模块还将所述内容分发网络实体的状态实时下发给软件自定义网络控制器。需要说明的是,第一软件定义网络转发设备向其所在区域的SDN控制器模块发起路由请求,所述路由请求携带有用户报文,所述用户报文包括:用户源IP(InternetProtocol,互联网协议)地址、用户源Port(端口)、目的IP地址、目的端口、目的应用层协议和访问资源的标识URL(Uniform Resource Locator,统一资源定位符)等信息。
在本发明实施例中,得到有效的内容分发网络实体所对应的转发链的信息的方式有很多种,以下对几种优选的实现方式进行举例说明。
可选地,可根据用户报文的源IP(Internet Protocol,互联网协议)地址、源端口、目的IP地址和/或目的端口和预存的所有内容分发网络实体的转发链的信息,得到有效的内容分发网络实体所对应的转发链的信息。
可选地,上述S201具体包括以下步骤:S2011~S2012。
S2011,根据所述用户报文的源IP地址、源端口、目的IP地址和/或目的端口和预存的内容分发网络实体的转发链的信息,确定与所述用户报文的源IP地址、源端口、目的IP地址和/或目的端口对应的一个或多个内容分发网络实体的转发链的信息;
S2012,根据确定的一个或多个内容分发网络实体的转发链的信息,以及内容分发网络实体的转发链状态,得到有效的内容分发网络实体的转发链的信息。
例如,所述多个内容分发网络实体的转发链的信息至少包括:第一内容分发网络实体的转发链的信息和第二内容分发网络实体的转发链的信息;则S2012包括以下步骤:S20121~S20123。
S20121,判断第一内容分发网络实体对应的转发链状态是否为异常;
S20122,若所述第一内容分发网络实体所对应的转发链状态不是异常状态,将所述第一内容分发网络实体所对应的转发链信息确定为有效的内容分发网络实体的转发链信息;
S20123,若所述第一内容分发网络实体所对应的转发链状态是异常状态,根据所述用户报文匹配得到的第二内容分发网络实体所对应的转发链信息,将所述第二内容分发网络实体所对应的转发链信息确定为有效的内容分发网络实体的转发链信息。
可选地,可根据所述用户报文和预存的所有内容分发网络实体的转发链的信息中转发链优先级,得到有效的内容分发网络实体的转发链的信息,其中,所述有效的内容分发网络实体的转发链的转发链优先级最高。
可选地,上述S201具体包括以下步骤:S2013~S2014。
S2013,根据所述用户报文的源IP地址、源端口、目的IP地址和/或目的端口,确定与所述用户报文的源IP地址、源端口、目的IP地址和/或目的端口对应的一个或多个有效的内容分发网络实体;
S2014,根据确定的一个或多个有效的内容分发网络实体,以及预存的内容分发网络实体的转发链的信息中转发链优先级,得到有效的内容分发网络实体的转发链的信息,其中,所述有效的内容分发网络实体的转发链的转发链优先级最高。需要说明的是,得到有效的内容分发网络实体所对应的转发链的信息的方式有多种,并不局限于以上方式,可以理解的是,在本发明实施例中并不具体限定得到有效的内容分发网络实体所对应的转发链的信息的方式。
S202,将所述有效的内容分发网络实体的转发链的信息转发给与所述有效的内容分发网络实体对应的软件定义网络转发设备,由所述软件定义网络转发设备将所述用户报文转发给所述有效的内容分发网络实体。
以图1所示的内容分发网络系统为例,与所述有效的内容分发网络实体对应的软件定义网络转发设备可为第一软件定义网络转发设备或第二软件定义网络转发设备。例如,若第一CDN节点为有效的内容分发网络实体,则所述第一软件定义网络转发设备即为与所述有效的内容分发网络实体对应的软件定义网络转发设备;若第二CDN节点为有效的内容分发网络实体,则所述第二软件定义网络转发设备即为与所述有效的内容分发网络实体对应的软件定义网络转发设备。需要说明的是,以上有关所述软件定义网络转发设备的相关描述只是示例并非限定。
在本发明实施中,在S201步骤之前,所述方法还包括:S203~S204。
S203,接收所有内容分发网络实体的状态,例如,可实时接收管理模块下发的所有内容分发网络实体的状态。
需要说明的是,可根据接收所有内容分发网络实体的状态来映射得到所有内容分发网络实体对应的转发链的状态。
S204,根据所有内容分发网络实体的状态,调整预存的所有内容分发网络实体的转发链的信息中转发链优先级。
具体地,若内容分发网络实体的状态为异常状态时,将处于异常状态的内容分发网络实体的转发链的信息中的转发链优先级置为最低。在本发明实施例中,用户终端到多个CDN节点之间有多条报文的转发链,通过软件定义网络控制器根据所述用户报文、所有内容分发网络实体的状态和预存的所有内容分发网络实体的转发链的信息,得到有效的内容分发网络实体所对应的转发链的信息;进而通过软件定义网络控制器根据所述有效的内容分发网络实体所对应的转发链的信息,将所述用户报文转发给所述有效的内容分发网络实体。
在本发明实施例中,将原先终端与处在网络中心的全局负载均衡服务器的多次七层交互实现的终端接入,改成终端与处在网络边缘的软件定义网络控制器和转发设备在网络的三层进行智能转发,对于用户终端的来说,在网络七层上,和内容分发网络实体之间只有一次交互。这样,所述CDN业务处理方法在用户终端请求CDN服务时,用户终端与CDN节点之间只发起一次应用层的连接,服务响应延迟低,可解决由于重定向导致的延迟问题。
基于上述的内容分发网络系统,为了解决由于重定向导致的延迟问题,本发明实施例提供了另一种CDN业务处理方法,图3为本发明实施例提供的另一种CDN业务处理方法的流程图,参见图3,所述方法包括以下步骤:
S301,接收所有内容分发网络实体的状态。
例如,可实时接收管理模块下发的所有内容分发网络实体的状态。
需要说明的是,可根据接收所有内容分发网络实体的状态,映射得到转发链的信息的内容分发网络实体对应的转发链的状态。
S302,根据预存的内容分发网络实体的转发链的信息,对所述用户报文信息进行匹配,得到第一内容分发网络实体对应的转发链信息;
可选地,软件定义网络控制器可根据用户报文和预存的所有内容分发网络实体所对应的转发链信息中的转发链的优先级,得到优先级最高的所述第一内容分发网络实体所对应的转发链的转发链信息。
S303,判断第一内容分发网络实体对应的转发链状态是否为异常。若所述第一内容分发网络实体所对应的转发链状态不是异常状态,执行步骤S304;若所述第一内容分发网络实体所对应的转发链状态是异常状态,执行步骤S305。
需要说明的是,若第一内容分发网络实体所对应的转发链状态为异常状态时,将第一内容分发网络实体的转发链信息中的转发链的优先级置为最低。
S304,若所述第一内容分发网络实体所对应的转发链状态不是异常状态,将所述第一内容分发网络实体所对应的转发链信息确定为有效的内容分发网络实体所对应的转发链信息。
S305,若所述第一内容分发网络实体所对应的转发链状态是异常状态,根据所述用户报文匹配得到的第二内容分发网络实体所对应的转发链信息,将所述第二内容分发网络实体所对应的转发链信息确定为有效的内容分发网络实体所对应的转发链信息。
可选地,可根据所述用户报文和存储的由管理模块下发的所有内容分发网络实体对应的转发链信息,得到第二内容分发网络实体对应的转发链信息。
在本实施例中,在CDN实体状态异常的时候,通过管理模块将CDN实体对应的转发链信息同步给SDN控制器模块。
在本实施例中,用户终端发起新的服务请求的时候,第一SDN转发设备将用户请求发送给SDN控制器模块。若所述第一内容分发网络实体所对应的转发链信息是异常状态,SDN控制器模块根据所述用户报文和存储的由管理模块下发的所有内容分发网络实体对应的转发链信息,得到第二内容分发网络实体对应的转发链信息,即SDN控制器模块直接选择新的转发路径,下发给第一SDN转发设备,第一SDN转发设备能够将用户的请求转发到新的CDN节点上,能够实现CDN节点之间用户服务的调度,用户服务不受影响。
S306,将所述有效的内容分发网络实体的转发链的信息转发给与所述有效的内容分发网络实体对应的软件定义网络转发设备,由所述软件定义网络转发设备将所述用户报文转发给所述有效的内容分发网络实体。
可选地,若所述第一内容分发网络实体所对应的转发链信息为有效的内容分发网络实体所对应的转发链信息,将所述第一内容分发网络实体所对应的转发链信息中的第一转发链的标识和第一软件定义网络转发设备的下一跳的第一地址信息转发给所述第一软件定义网络转发设备,由所述第一软件定义网络转发设备根据所述第一转发链的标识和下一跳的第一地址信息将所述用户报文转发给所述第一内容分发网络实体。
在本实施例中,所述第一地址信息用于表示所述第一软件定义网络转发设备的下一跳的网络设备的位置等相关信息,所述第一地址信息包括IP、Port和MAC(Media AccessControl,媒体访问控制)地址。
可选地,若所述第二内容分发网络实体所对应的转发链信息为有效的内容分发网络实体所对应的转发链信息时,所述S306具体包括以下步骤:S3061~S3062。
S3061,将所述第二内容分发网络实体对应的转发链信息中第二转发链的标识和第一软件定义网络转发设备的下一跳的第二地址信息转发给第一软件定义网络转发设备;由所述第一软件定义网络转发设备根据所述第二转发链的标识和下一跳的第二地址信息,将用户报文转发给第二软件定义网络转发设备。
S3062,将所述第二内容分发网络实体对应的转发链信息中第二转发链的标识和第二软件定义网络转发设备的下一跳的第三地址信息转发给第二软件定义网络转发设备;由所述第二软件定义网络转发设备根据所述第二转发链的标识和下一跳的第三地址信息将用户报文转发给所述第二内容分发网络实体。
在本实施例中,用户终端到多个CDN节点之间有多条报文的转发链,通过软件定义网络控制器可根据所述用户报文和存储的由管理模块下发的所有内容分发网络实体对应的转发链信息,对用户报文中的信息进行匹配,得到第一内容分发网络实体所对应的转发链信息;若所述第一内容分发网络实体所对应的转发链信息不是异常状态,根据所述第一内容分发网络实体所对应的转发链信息对用户报文进行转发;若所述第一内容分发网络实体所对应的转发链信息是异常状态,根据所述用户报文匹配得到的第二内容分发网络实体所对应的转发链信息,根据所述第二内容分发网络实体所对应的转发链信息对用户报文进行转发。这样,所述CDN业务处理方法在用户终端请求CDN服务时,用户终端与CDN节点之间只发起一次应用层的连接,服务响应延迟低,可解决由于重定向导致的延迟问题。同时,与传统CDN的采用的GSLB多次重定向方式相比,上述选择方式没有中心的调度模块,因此没有单点故障的问题,可解决用户终端到调度节点的网络发生故障而导致业务瘫痪的技术问题。
为了便于理解上述的CDN业务处理方法,以下结合附图进行举例说明。
基于图1所示的内容分发网络系统,本发明实施例提供了一种CDN业务处理方法,该方法用于用户终端请求第一CDN节点服务,参见图4,所述方法包括以下步骤:
步骤401,配置CDN节点转发链消息。
其中,管理模块配置2个转发链:转发链1和转发链2。其中,转发链1的转发链信息包含:路径ID1、HTTP协议、服务IP,目的节点是第一CDN节点,路径的第一跳是第一SDN转发设备,第二跳第一CDN节点,优先级高;转发链2的转发链的信息包含:路径ID2、HTTP协议、服务IP,目的节点是第二CDN节点,路径第1跳是第一SDN转发设备,第2跳是第二SDN转发设备,第3跳的设备是第二CDN节点,优先级低。
步骤402,管理模块将转发链1和转发链2下发给SDN控制器。
步骤403,用户终端向第一SDN转发设备发送TCP握手报文,即用户终端开始发起CDN的HTTP服务请求,HTTP服务请求所访问的内容是HTTP业务资源标识URL,用户终端向其相邻的第一SDN转发设备发起TCP三次握手。
步骤404,封装用户报文,并且转发。
其中,在第一个TCP握手报文达到第一SDN转发设备时,第一SDN转发设备封装用户报文,向SDN控制器发起用户终端的路由请求,路由请求包含用户报文中的信息,其中有CDN服务IP和Port。
步骤405,返回转发链1的第一CDN节点地址。
具体地,SDN控制器模块根据用户访问的CDN服务IP,在转发链1和转发链2中继进行匹配,采用优先级高的转发链1,把下一跳第一CDN节点的地址(IP,Port,MAC)返回给第一SDN转发设备。
步骤406,转发用户报文。
第一SDN转发设备根据SDN控制器设备返回的下一跳第一CDN节点的IP、Port和MAC地址生成流表项,该流表项包括:用户终端IP作为源IP,服务IP作为目的IP,动作是转发给下一跳第一CDN节点的MAC地址。
步骤407,第一CDN节点返回TCP握手响应给第一SDN转发设备。
步骤408,第一SDN转发设备返回TCP握手响应给用户终端。
第一SDN转发设备根据前面步骤中创建的流表项,将CDN节点的TCP握手响应返回给用户终端;
步骤409,第三次TCP握手报文。
用户终端与第一CDN节点之间,通过第一SDN转发设备进行剩下的TCP交互操作,发起TCP第三次握手的报文,报文经过第一SDN转发设备,到第一CDN节点,建立TCP连接,之后在该TCP连接上,继续交互生成HTTP会话,开始获取第一CDN节点的服务。
步骤410,获取CDN HTTP服务。
在本发明实施例中,用户到多个CDN节点的报文转发路径,直接有管理配置下发给SDN控制器,保存后,能够根据用户请求报文中的信息进行匹配。用户在请求CDN服务时,用户终端与CDN节点之间只发起一次应用层的连接,服务响应延迟低。
为了便于更好理解转发链的信息的更新流程,本发明实施例提供了另一种CDN业务处理方法,用于转发链的信息的更新过程,参加图5,所述方法包括以下步骤:
步骤501,第一CDN节点周期性的向管理模块上报状态。
步骤502,第二CDN节点周期性的向管理模块上报状态。
步骤503,管理模块周期性地监测第一CDN节点的状态是否异常,如果第一CDN节点的状态异常,则将第一CDN节点对应的转发链的信息置为异常状态,并且通知SDN控制器模块。
步骤504,更新转发链的信息。
需要说明的是,管理模块将异常节点的转发链1异常的信息下发给SDN控制器,SDN控制器更将转发链1的优先级置为最低。
基于图1所示的内容分发网络系统,本发明实施例提供了又一种CDN业务处理方法,该方法用于用户终端请求第二CDN节点服务,参见图6,所述方法包括以下步骤:
步骤601,用户终端向第一SDN转发设备发起TCP握手报文,即用户终端开始发起CDN节点的HTTP服务请求,所述HTTP服务请求访问的内容是HTTP业务资源标识URL,该请求的终端向其相邻的第一SDN转发设备发起TCP三次握手。
步骤602,封装用户报文,并且转发。在第一次TCP握手报文达到第一SDN转发设备时,第一SDN转发设备封装用户报文,向SDN控制器发起用户终端的路由请求,路由请求包含用户报文中的信息,其中有CDN服务IP和Port。
步骤603,返回转发链2的第二跳信息。
具体地,SDN控制器模块根据用户访问的CDN服务IP和Port在转发链1和转发链2中继进行匹配,采用优先级高的转发链2,转发链2的第二跳为第二SDN转发设备,将第二SDN转发设备的地址(IP,Port,MAC)返回给第一SDN转发设备。
步骤604,转发用户握手报文。
具体地,第一SDN转发设备根据SDN控制器设备返回的下一跳CDN节点的IP、Port和MAC地址生成流表项。该流表项包括:用户终端IP作为源IP,服务IP作为目的IP,动作是转发给下一跳第二SDN转发设备。
步骤605,第二SDN转发设备封装用户报文并且转发。
具体地,第二SDN转发设备封装用户TCP握手报文,向SDN控制器发起路由请求,该用户终端的路由请求,路由请求包含用户报文中的信息,其中有CDN服务IP和Port;
步骤606,SDN控制器模块返回转发链2的第三跳信息。
具体地,SDN控制器模块根据用户访问的CDN服务IP和Port,在转发链1和转发链2中继进行匹配,采用优先级高的转发链2,转发链2的第三跳为第二CDN节点,把第二CDN节点的地址(IP,Port,MAC)返回给第二SDN转发设备。
步骤607,第二SDN转发设备转发用户握手报文。
具体地,第二SDN转发设备根据SDN控制器设备返回的下一跳第二CDN节点的IP、Port和MAC地址生成流表项。该流表项包括:用户终端IP作为源IP,服务IP作为目的IP,动作是转发给下一跳第二CDN节点。
步骤608,第二CDN节点返回TCP握手响应给第二SDN转发设备。
步骤609,第二SDN转发设备返回TCP握手响应。
具体地,第二SDN转发设备根据流表项将CDN节点的握手响应返回给第一SDN转发设备。
步骤610,第一SDN转发设备返回TCP握手响应。
具体地,第一SDN转发设备根据流表项将第二SDN转发设备返回的握手响应返回给用户终端。
步骤611,获取CDN HTTP服务。
用户终端与第二CDN节点之间进行剩下的TCP交互操作,发起TCP第三次握手的报文,报文经过第一SDN转发设备转发给第二SDN转发设备,再由第二SDN转发设备转发到第二CDN节点,建立TCP连接之后,在该TCP连接上,继续交互生成HTTP会话,开始获取第二CDN节点的服务。
需要说明的是,本发明公开的基于SDN的CDN系统和CDN实体的选择方法有多种变形方式,比如多个用户终端到CDN之间不完全是SDN转发设备,可以是现有的数据设备。
在本发明实施例中,在CDN节点状态异常的时候,通过管理模块将CDN节点对应的转发链的信息同步给SDN控制器模块,用户发起新的服务请求的时候,SDN转发设备将用户请求发送给SDN控制器模块,SDN控制器模块直接选择新的转发路径,下发给SDN转发设备,SDN转发设备能够将用户的请求转发到新的CDN节点上,即能够实现CDN节点之间用户服务的调度,用户服务不受影响。与传统CDN的采用的GSLB多次重定向方式相比,本发明实施例的CDN业务处理方法没有中心的调度模块,因此没有单点故障的问题。
图7为本发明实施例提供的一种软件定义网络控制器的结构示意图,参见图7,所述软件定义网络控制器700包括:接收子模块701、匹配子模块702和转发子模块703。其中,
所述接收子模块701,用于接收所有内容分发网络实体的状态。
所述匹配子模块702,用于接收用户报文,根据所述用户报文和预存的内容分发网络实体的转发链的信息,得到有效的内容分发网络实体所对应的转发链的信息;其中,所述有效的内容分发网络实体是指内容分发网络实体所对应的转发链无异常和/或所述有效的内容分发网络实体的转发链的转发链优先级最高。
可选地,所述匹配子模块702包括:第一匹配单元和第一确定单元。
所述第一匹配单元,用于根据所述用户报文的源IP地址、源端口、目的IP地址和/或目的端口,以及预存的所有内容分发网络实体的转发链的信息,确定与所述用户报文的源IP地址、源端口、目的IP地址和/或目的端口对应的一个或多个内容分发网络实体的转发链的信息;
第一确定单元,根据确定的一个或多个内容分发网络实体的转发链的信息,以及内容分发网络实体的转发链状态,得到有效的内容分发网络实体的转发链的信息。
可选地,所述多个内容分发网络实体的转发链的信息至少包括:第一内容分发网络实体的转发链的信息和第二内容分发网络实体的转发链的信息;
所述第一确定单元包括:判断子单元、第一确定子单元和第二确定子单元。
判断子单元,用于判断第一内容分发网络实体对应的转发链状态是否为异常;
第一确定子单元,用于若所述第一内容分发网络实体所对应的转发链状态不是异常状态,将所述第一内容分发网络实体所对应的转发链信息确定为有效的内容分发网络实体的转发链信息;
第二确定子单元,用于若所述第一内容分发网络实体所对应的转发链状态是异常状态,根据所述用户报文匹配得到的第二内容分发网络实体所对应的转发链信息,将所述第二内容分发网络实体所对应的转发链信息确定为有效的内容分发网络实体的转发链信息。
可选地,所述匹配子模块包括:第二确定单元和第三确定单元。其中,
所述第二确定单元,用于根据所述用户报文的源IP地址、源端口、目的IP地址和/或目的端口,确定与所述用户报文的源IP地址、源端口、目的IP地址和/或目的端口对应的一个或多个有效的内容分发网络实体;
所述第三确定单元,用于根据确定的一个或多个有效的内容分发网络实体,以及预存的内容分发网络实体的转发链的信息中转发链优先级,得到有效的内容分发网络实体的转发链的信息,其中,所述有效的内容分发网络实体的转发链的转发链优先级最高。
除此之外,所述软件定义网络控制器还包括:调整模块。
所述调整模块,用于根据所有内容分发网络实体的状态,调整预存的所有内容分发网络实体的转发链的信息中转发链优先级。
其中,所述调整模块包括:调整子模块。
所述调整子模块,用于若内容分发网络实体的状态为异常状态时,将处于异常状态的内容分发网络实体的转发链的信息中的转发链优先级置为最低。
所述转发子模块703,用于将所述有效的内容分发网络实体的转发链的信息转发给与所述有效的内容分发网络实体相对应的软件定义网络转发设备,由所述软件定义网络转发设备将所述用户报文转发给所述有效的内容分发网络实体。
需要说明的是,若所述第一内容分发网络实体所对应的转发链的信息不是异常状态,所述转发子模块703包括:第一转发单元。
所述第一转发单元,用于将所述第一内容分发网络实体所对应的转发链的信息中的第一转发链的标识和第一软件定义网络转发设备的下一跳的第一地址信息转发给所述第一软件定义网络转发设备,由所述第一软件定义网络转发设备根据所述第一转发链的标识和下一跳的第一地址信息将所述用户报文转发给所述第一内容分发网络实体。
需要说明的是,当若所述第一内容分发网络实体的状态是异常状态时,所述转发子模块703还包括:第二转发单元和第三转发单元。
其中,所述第二转发单元,用于可将所述第二内容分发网络实体对应的转发链的信息中第二转发链的标识和第一软件定义网络转发设备的下一跳的第二地址信息转发给第一软件定义网络转发设备;由所述第一软件定义网络转发设备根据所述第二转发链的标识和下一跳的第二地址信息,将用户报文转发给第二软件定义网络转发设备。
所述第三转发单元,用于将所述第二内容分发网络实体对应的转发链的信息中第二转发链的标识和第二软件定义网络转发设备的下一跳的第三地址信息转发给第二软件定义网络转发设备;由所述第二软件定义网络转发设备根据所述第二转发链的标识和下一跳的第三地址信息将用户报文转发给所述第二内容分发网络实体。
需要说明的是,上述软件定义网络控制器可实现CDN业务处理方法的各个步骤,在此不在赘述。
首先,通过所述匹配子模块根据所述用户报文,得到有效的第一内容分发网络实体所对应的转发链的信息;进而通过所述转发子模块根据所述有效的内容分发网络实体所对应的转发链的信息,将所述用户报文转发给所述有效的内容分发网络实体。这样,所述CDN业务处理方法在用户终端请求CDN服务时,用户终端与CDN节点之间只发起一次应用层的连接,服务响应延迟低,可解决由于重定向导致的延迟问题。
其次,根据所述用户报文匹配得到第一内容分发网络实体所对应的转发链的信息;若所述第一内容分发网络实体的状态不是异常状态,通过第一确定子单元将所述第一内容分发网络实体的转发链的信息确定为有效的内容分发网络实体的转发链的信息;若所述第一内容分发网络实体的状态是异常状态,通过所述第二确定子单元根据所述用户报文匹配得到的第二内容分发网络实体所对应的转发链的信息,将所述第二内容分发网络实体所对应的转发链的信息确定为有效的内容分发网络实体所对应的转发链的信息,这样在CDN实体状态异常的时候,能够实现CDN节点之间用户服务的调度,用户服务不受影响,与传统CDN的采用的GSLB多次重定向方式相比,这种方式没有中心的调度模块,因此没有单点故障的问题,可解决用户终端到调度节点的网络发生故障而导致业务瘫痪的问题。
图8为本发明另一实施例提供的软件定义网络控制器的结构示意图。如图8所示,图8所示的软件定义网络控制器800包括:处理器801、收发机802、存储器803、用户接口804和总线接口,其中:
在本发明实施例中,软件定义网络控制器800还包括:存储在存储器803上并可在处理器801上运行的计算机程序,计算机程序被处理器801、执行时实现如下步骤:
接收用户报文,根据所述用户报文和预存的所有内容分发网络实体的转发链的信息,得到有效的内容分发网络实体所对应的转发链的信息;其中,所述有效的内容分发网络实体是指内容分发网络实体所对应的转发链无异常和/或所述有效的内容分发网络实体的转发链的转发链优先级最高;将所述有效的内容分发网络实体的转发链的信息转发给与所述有效的内容分发网络实体相对应的软件定义网络转发设备,由所述软件定义网络转发设备将所述用户报文转发给所述有效的内容分发网络实体。
在图8中,总线架构可以包括任意数量的互联的总线和桥,具体由处理器801代表的一个或多个处理器和存储器803代表的存储器的各种电路链接在一起。总线架构还可以将诸如外围设备、稳压器和功率管理电路等之类的各种其他电路链接在一起,这些都是本领域所公知的,因此,本文不再对其进行进一步描述。总线接口提供接口。收发机802可以是多个元件,即包括发送机和接收机,提供用于在传输介质上与各种其他装置通信的单元。针对不同的用户设备,用户接口804还可以是能够外接内接需要设备的接口,连接的设备包括但不限于小键盘、显示器、扬声器、麦克风、操纵杆等。
处理器801负责管理总线架构和通常的处理,存储器803可以存储处理器801在执行操作时所使用的数据。
可选的,计算机程序被处理器801执行时还可实现如下步骤:
根据所述用户报文的源IP地址、源端口、目的IP地址和/或目的端口和预存的内容分发网络实体的转发链的信息,确定与所述用户报文的源IP地址、源端口、目的IP地址和/或目的端口对应的一个或多个内容分发网络实体的转发链的信息;根据确定的一个或多个内容分发网络实体的转发链的信息,以及内容分发网络实体的转发链状态,得到有效的内容分发网络实体的转发链的信息。
可选的,计算机程序被处理器801执行时还可实现如下步骤:
判断第一内容分发网络实体对应的转发链状态是否为异常;若所述第一内容分发网络实体所对应的转发链状态不是异常状态,将所述第一内容分发网络实体所对应的转发链信息确定为有效的内容分发网络实体的转发链信息;若所述第一内容分发网络实体所对应的转发链状态是异常状态,根据所述用户报文匹配得到的第二内容分发网络实体所对应的转发链信息,将所述第二内容分发网络实体所对应的转发链信息确定为有效的内容分发网络实体的转发链信息。
可选的,计算机程序被处理器801执行时还可实现如下步骤:
若内容分发网络实体的状态为异常状态时,将处于异常状态的内容分发网络实体的转发链的信息中的转发链优先级置为最低。
可选的,计算机程序被处理器801执行时还可实现如下步骤:
根据所述用户报文的源IP地址、源端口、目的IP地址和/或目的端口,确定与所述用户报文的源IP地址、源端口、目的IP地址和/或目的端口对应的一个或多个有效的内容分发网络实体;根据确定的一个或多个有效的内容分发网络实体,以及预存的内容分发网络实体的转发链的信息中转发链优先级,得到有效的内容分发网络实体的转发链的信息,其中,所述有效的内容分发网络实体的转发链的转发链优先级最高。
首先,通过所述处理器801块根据所述用户报文,得到有效的第一内容分发网络实体所对应的转发链的信息;进而通过所述处理器801根据所述有效的内容分发网络实体所对应的转发链的信息,将所述用户报文转发给所述有效的内容分发网络实体。这样,所述CDN业务处理方法在用户终端请求CDN服务时,用户终端与CDN节点之间只发起一次应用层的连接,服务响应延迟低,可解决由于重定向导致的延迟问题。
其次,通过所述处理器801根据所述用户报文匹配得到第一内容分发网络实体所对应的转发链的信息;若所述第一内容分发网络实体的状态是异常状态,通过所述处理器801根据所述用户报文匹配得到的第二内容分发网络实体所对应的转发链的信息,将所述第二内容分发网络实体所对应的转发链的信息确定为有效的内容分发网络实体所对应的转发链的信息,这样在CDN实体状态异常的时候,能够实现CDN节点之间用户服务的调度,用户服务不受影响,与传统CDN的采用的GSLB多次重定向方式相比,这种方式没有中心的调度模块,因此没有单点故障的问题,可解决用户终端到调度节点的网络发生故障而导致业务瘫痪的问题。
本发明实施例还提供了一种计算机可读存储介质,其上存储有计算机程序,该程序被处理器执行时实现如上所述的CDN业务处理方法中的步骤。
应理解,说明书通篇中提到的“一个实施例”或“一实施例”意味着与实施例有关的特定特征、结构或特性包括在本发明的至少一个实施例中。因此,在整个说明书各处出现的“在一个实施例中”或“在一实施例中”未必一定指相同的实施例。此外,这些特定的特征、结构或特性可以任意适合的方式结合在一个或多个实施例中。
在本发明的各种实施例中,应理解,上述各过程的序号的大小并不意味着执行顺序的先后,各过程的执行顺序应以其功能和内在逻辑确定,而不应对本发明实施例的实施过程构成任何限定。
在本申请所提供的实施例中,应理解,“与A相应的B”表示B与A相关联,根据A可以确定B。但还应理解,根据A确定B并不意味着仅仅根据A确定B,还可以根据A和/或其它信息确定B。
在本申请所提供的几个实施例中,应该理解到,所揭露方法和装置,可以通过其它的方式实现。例如,以上所描述的装置实施例仅仅是示意性的,例如,所述单元的划分,仅仅为一种逻辑功能划分,实际实现时可以有另外的划分方式,例如多个单元或组件可以结合或者可以集成到另一个系统,或一些特征可以忽略,或不执行。另一点,所显示或讨论的相互之间的耦合或直接耦合或通信连接可以是通过一些接口,装置或单元的间接耦合或通信连接,可以是电性,机械或其它的形式。
另外,在本发明各个实施例中的各功能单元可以集成在一个处理单元中,也可以是各个单元单独物理包括,也可以两个或两个以上单元集成在一个单元中。上述集成的单元既可以采用硬件的形式实现,也可以采用硬件加软件功能单元的形式实现。
上述以软件功能单元的形式实现的集成的单元,可以存储在一个计算机可读取存储介质中。上述软件功能单元存储在一个存储介质中,包括若干指令用以使得一台计算机设备(可以是个人计算机,服务器,或者网络侧设备等)执行本发明各个实施例所述收发方法的部分步骤。而前述的存储介质包括:U盘、移动硬盘、只读存储器(Read-Only Memory,简称ROM)、随机存取存储器(Random Access Memory,简称RAM)、磁碟或者光盘等各种可以存储程序代码的介质。
以上所述是本发明的优选实施方式,应当指出,对于本技术领域的普通技术人员来说,在不脱离本发明所述原理的前提下,还可以作出若干改进和润饰,这些改进和润饰也应视为本发明的保护范围。
Claims (13)
1.一种内容分发网络实体CDN业务处理方法,适用于软件定义网络控制器,其特征在于,包括:
接收用户报文,根据所述用户报文和预存的内容分发网络实体的转发链的信息,得到有效的内容分发网络实体的转发链的信息;其中,所述有效的内容分发网络实体是指内容分发网络实体所对应的转发链无异常和/或所述有效的内容分发网络实体的转发链的转发链优先级最高;
将所述有效的内容分发网络实体的转发链的信息转发给与所述有效的内容分发网络实体对应的软件定义网络转发设备,由所述软件定义网络转发设备将所述用户报文转发给所述有效的内容分发网络实体。
2.根据权利要求1所述的方法,其特征在于,所述根据所述用户报文和预存的内容分发网络实体的转发链的信息,得到有效的内容分发网络实体的转发链的信息,包括:
根据所述用户报文的源IP地址、源端口、目的IP地址和/或目的端口和预存的内容分发网络实体的转发链的信息,确定与所述用户报文的源IP地址、源端口、目的IP地址和/或目的端口对应的一个或多个内容分发网络实体的转发链的信息;
根据确定的一个或多个内容分发网络实体的转发链的信息,以及内容分发网络实体的转发链状态,得到有效的内容分发网络实体的转发链的信息。
3.根据权利要求2所述的方法,其特征在于,所述多个内容分发网络实体的转发链的信息至少包括:第一内容分发网络实体的转发链的信息和第二内容分发网络实体的转发链的信息;
所述根据确定的多个内容分发网络实体的转发链的信息,以及所有内容分发网络实体的状态,得到有效的内容分发网络实体的转发链的信息,包括:
判断第一内容分发网络实体对应的转发链状态是否为异常;
若所述第一内容分发网络实体所对应的转发链状态不是异常状态,将所述第一内容分发网络实体所对应的转发链信息确定为有效的内容分发网络实体的转发链信息;
若所述第一内容分发网络实体所对应的转发链状态是异常状态,根据所述用户报文匹配得到的第二内容分发网络实体所对应的转发链信息,将所述第二内容分发网络实体所对应的转发链信息确定为有效的内容分发网络实体的转发链信息。
4.根据权利要求1所述的方法,其特征在于,在根据所述用户报文和预存的内容分发网络实体的转发链的信息,得到有效的内容分发网络实体的转发链的信息的步骤之前,所述方法还包括:
若内容分发网络实体的状态为异常状态时,将处于异常状态的内容分发网络实体的转发链的信息中的转发链优先级置为最低。
5.根据权利要求1所述的方法,其特征在于,所述根据所述用户报文和预存的内容分发网络实体的转发链的信息,得到有效的内容分发网络实体的转发链的信息,包括:
根据所述用户报文的源IP地址、源端口、目的IP地址和/或目的端口,确定与所述用户报文的源IP地址、源端口、目的IP地址和/或目的端口对应的一个或多个有效的内容分发网络实体;
根据确定的一个或多个有效的内容分发网络实体,以及预存的内容分发网络实体的转发链的信息中转发链优先级,得到有效的内容分发网络实体的转发链的信息,其中,所述有效的内容分发网络实体的转发链的转发链优先级最高。
6.一种软件定义网络控制器,其特征在于,包括:
匹配子模块,用于接收用户报文,根据所述用户报文和预存的内容分发网络实体的转发链的信息,得到有效的内容分发网络实体所对应的转发链的信息;其中,所述有效的内容分发网络实体是指内容分发网络实体所对应的转发链无异常和/或所述有效的内容分发网络实体的转发链的转发链优先级最高;
转发子模块,用于将所述有效的内容分发网络实体的转发链的信息转发给与所述有效的内容分发网络实体对应的软件定义网络转发设备,由所述软件定义网络转发设备将所述用户报文转发给所述有效的内容分发网络实体。
7.根据权利要求6所述的软件定义网络控制器,其特征在于,所述匹配子模块包括:
第一匹配单元,用于根据所述用户报文的源IP地址、源端口、目的IP地址和/或目的端口,以及预存的内容分发网络实体的转发链的信息,确定与所述用户报文的源IP地址、源端口、目的IP地址和/或目的端口对应的一个或多个内容分发网络实体的转发链的信息;
第一确定单元,根据确定的一个或多个内容分发网络实体的转发链的信息,以及内容分发网络实体的转发链状态,得到有效的内容分发网络实体的转发链的信息。
8.根据权利要求7所述的软件定义网络控制器,其特征在于,所述多个内容分发网络实体的转发链的信息至少包括:第一内容分发网络实体的转发链的信息和第二内容分发网络实体的转发链的信息;
所述第一确定单元包括:
判断子单元,用于判断第一内容分发网络实体对应的转发链状态是否为异常;
第一确定子单元,用于若所述第一内容分发网络实体所对应的转发链状态不是异常状态,将所述第一内容分发网络实体所对应的转发链信息确定为有效的内容分发网络实体的转发链信息;
第二确定子单元,用于若所述第一内容分发网络实体所对应的转发链状态是异常状态,根据所述用户报文匹配得到的第二内容分发网络实体所对应的转发链信息,将所述第二内容分发网络实体所对应的转发链信息确定为有效的内容分发网络实体的转发链信息。
9.根据权利要求6所述的软件定义网络控制器,其特征在于,所述软件定义网络控制器还包括:
调整子模块,用于若内容分发网络实体的状态为异常状态时,将处于异常状态的内容分发网络实体的转发链的信息中的转发链优先级置为最低。
10.根据权利要求6所述的软件定义网络控制器,其特征在于,所述匹配子模块,包括:
第二确定单元,用于根据所述用户报文的源IP地址、源端口、目的IP地址和/或目的端口,确定与所述用户报文的源IP地址、源端口、目的IP地址和/或目的端口对应的一个或多个有效的内容分发网络实体;
第三确定单元,用于根据确定的一个或多个有效的内容分发网络实体,以及预存的内容分发网络实体的转发链的信息中转发链优先级,得到有效的内容分发网络实体的转发链的信息,其中,所述有效的内容分发网络实体的转发链的转发链优先级最高。
11.一种内容分发网络系统,其特征在于,包括:用于生成内容分发网络实体的转发链的信息的管理模块、一个或至少两个软件定义网络转发设备、一个或至少两个内容分发网络实体以及一个或至少两个如权利要求7~12任一项所述的软件定义网络控制器。
12.一种软件定义网络控制器,其特征在于,包括:存储器、处理器及存储在存储器上并可在处理器上运行的计算机程序,所述处理器执行所述程序时实现如权利要求1~5任一项所述的CDN业务处理方法中的步骤。
13.一种计算机可读存储介质,其上存储有计算机程序,其特征在于,该程序被处理器执行时实现如权利要求1~5任一项所述的CDN业务处理方法中的步骤。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201710889657.1A CN109561057A (zh) | 2017-09-27 | 2017-09-27 | 一种内容分发网络实体业务处理方法、装置及系统 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201710889657.1A CN109561057A (zh) | 2017-09-27 | 2017-09-27 | 一种内容分发网络实体业务处理方法、装置及系统 |
Publications (1)
Publication Number | Publication Date |
---|---|
CN109561057A true CN109561057A (zh) | 2019-04-02 |
Family
ID=65863764
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN201710889657.1A Pending CN109561057A (zh) | 2017-09-27 | 2017-09-27 | 一种内容分发网络实体业务处理方法、装置及系统 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN109561057A (zh) |
Cited By (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN114785778A (zh) * | 2022-03-10 | 2022-07-22 | 聚好看科技股份有限公司 | 网关设备和内容分发方法 |
Citations (8)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN103795805A (zh) * | 2014-02-27 | 2014-05-14 | 中国科学技术大学苏州研究院 | 基于sdn的分布式服务器负载均衡方法 |
CN104301146A (zh) * | 2014-10-23 | 2015-01-21 | 杭州华三通信技术有限公司 | 软件定义网络中的链路切换方法和装置 |
WO2016081506A1 (en) * | 2014-11-18 | 2016-05-26 | Ustream, Inc. | Software defined content delivery network for flexible, real-time management of large-scale data transfers |
CN106534360A (zh) * | 2016-12-13 | 2017-03-22 | 重庆大学 | 一种基于软件定义的内容中心网络路由方法 |
CN106559336A (zh) * | 2015-09-24 | 2017-04-05 | 杭州华三通信技术有限公司 | 应用于sdn中的路径倒换方法和装置 |
CN106789650A (zh) * | 2016-12-23 | 2017-05-31 | 锐捷网络股份有限公司 | 基于ip的广域网加速方法及装置 |
CN106850859A (zh) * | 2017-03-28 | 2017-06-13 | 浙江大学 | 一种基于sdn的cdn网络的用户请求分配方法 |
EP3217598A1 (en) * | 2016-03-11 | 2017-09-13 | Wipro Limited | Method and system for achieving improved quality of service (qos) for content delivery in a sdn controller based communication network |
-
2017
- 2017-09-27 CN CN201710889657.1A patent/CN109561057A/zh active Pending
Patent Citations (8)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN103795805A (zh) * | 2014-02-27 | 2014-05-14 | 中国科学技术大学苏州研究院 | 基于sdn的分布式服务器负载均衡方法 |
CN104301146A (zh) * | 2014-10-23 | 2015-01-21 | 杭州华三通信技术有限公司 | 软件定义网络中的链路切换方法和装置 |
WO2016081506A1 (en) * | 2014-11-18 | 2016-05-26 | Ustream, Inc. | Software defined content delivery network for flexible, real-time management of large-scale data transfers |
CN106559336A (zh) * | 2015-09-24 | 2017-04-05 | 杭州华三通信技术有限公司 | 应用于sdn中的路径倒换方法和装置 |
EP3217598A1 (en) * | 2016-03-11 | 2017-09-13 | Wipro Limited | Method and system for achieving improved quality of service (qos) for content delivery in a sdn controller based communication network |
CN106534360A (zh) * | 2016-12-13 | 2017-03-22 | 重庆大学 | 一种基于软件定义的内容中心网络路由方法 |
CN106789650A (zh) * | 2016-12-23 | 2017-05-31 | 锐捷网络股份有限公司 | 基于ip的广域网加速方法及装置 |
CN106850859A (zh) * | 2017-03-28 | 2017-06-13 | 浙江大学 | 一种基于sdn的cdn网络的用户请求分配方法 |
Cited By (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN114785778A (zh) * | 2022-03-10 | 2022-07-22 | 聚好看科技股份有限公司 | 网关设备和内容分发方法 |
CN114785778B (zh) * | 2022-03-10 | 2023-09-01 | 聚好看科技股份有限公司 | 网关设备和内容分发方法 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
JP6503575B2 (ja) | ソフトウェアデファインドネットワークに基づいてコンテンツディストリビューションネットワークを実現する方法及びシステム | |
KR102519409B1 (ko) | 다중 경로 미디어 전달을 위한 방법 및 장치 | |
CN109150576B (zh) | 一种内容数据传输方法及设备 | |
JP6562570B2 (ja) | ソフトウェアデファインドネットワークに基づいてコンテンツディストリビューションネットワークを実現する方法及びシステム | |
US8223767B2 (en) | Driven multicast traffic distribution on link-aggregate-group | |
CN110381162B (zh) | 一种业务处理的方法以及相关装置 | |
CN108668178B (zh) | 一种组播实现方法及相关网络设备 | |
EP2787762A1 (en) | Method and system for adaptation, shunting transmission and stream switching of collaborative service | |
WO2018145376A1 (zh) | 一种无线设备共享带宽的控制方法及系统 | |
CN108566286B (zh) | 一种智能路由器服务质量的实现方法、路由器及电子设备 | |
EP3057287A1 (en) | Node allocation method, device and system | |
US20090092142A1 (en) | Methods, systems and computer program products for dynamic communication data routing by a multi-network remote communication terminal | |
US20150127837A1 (en) | Relay apparatus and data transfer method | |
CN101938467B (zh) | 一种支持跨网络的实现多媒体会话拆分的通信系统和方法 | |
Gama et al. | Video streaming analysis in multi-tier edge-cloud networks | |
CN109561057A (zh) | 一种内容分发网络实体业务处理方法、装置及系统 | |
CN104780591B (zh) | 终端设备间业务互操作实现方法、装置、系统及相关设备 | |
CN114095417B (zh) | 一种可编程的路由交换机、系统及方法 | |
Ververidis et al. | Experimenting with services over an information-centric integrated satellite-terrestrial network | |
JP3727572B2 (ja) | コンテンツ配信ネットワーク、アドレス通知端末、および通信制御装置 | |
KR101082786B1 (ko) | 프록시 서버를 이용한 컨텐츠 분배 시스템 및 방법 | |
CN113840151A (zh) | Ott组播网关调度方法、装置和系统、存储介质 | |
KR101530647B1 (ko) | 고품질 서비스를 위한 트래픽 처리 방법 및 그 장치 | |
US12010012B2 (en) | Application-aware BGP path selection and forwarding | |
KR20240099888A (ko) | 콘텐츠 라우팅 시스템 및 방법 |
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 | ||
RJ01 | Rejection of invention patent application after publication | ||
RJ01 | Rejection of invention patent application after publication |
Application publication date: 20190402 |