CN107003980A - 内容传送框架中的请求处理 - Google Patents

内容传送框架中的请求处理 Download PDF

Info

Publication number
CN107003980A
CN107003980A CN201580068160.2A CN201580068160A CN107003980A CN 107003980 A CN107003980 A CN 107003980A CN 201580068160 A CN201580068160 A CN 201580068160A CN 107003980 A CN107003980 A CN 107003980A
Authority
CN
China
Prior art keywords
request
content
services
information
general
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
Application number
CN201580068160.2A
Other languages
English (en)
Other versions
CN107003980B (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.)
Level 3 Communications LLC
Original Assignee
Level 3 Communications LLC
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 Level 3 Communications LLC filed Critical Level 3 Communications LLC
Publication of CN107003980A publication Critical patent/CN107003980A/zh
Application granted granted Critical
Publication of CN107003980B publication Critical patent/CN107003980B/zh
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/50Network services
    • H04L67/60Scheduling or organising the servicing of application requests, e.g. requests for application data transmissions using the analysis and optimisation of the required network resources
    • H04L67/63Routing a service request depending on the request content or context
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/01Protocols
    • H04L67/10Protocols in which an application is distributed across nodes in the network
    • H04L67/1097Protocols in which an application is distributed across nodes in the network for distributed storage of data in networks, e.g. transport arrangements for network file system [NFS], storage area networks [SAN] or network attached storage [NAS]
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/01Protocols
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/01Protocols
    • H04L67/02Protocols based on web technology, e.g. hypertext transfer protocol [HTTP]
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/50Network services
    • H04L67/56Provisioning of proxy services
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/50Network services
    • H04L67/56Provisioning of proxy services
    • H04L67/568Storing data temporarily at an intermediate stage, e.g. caching

Landscapes

  • Engineering & Computer Science (AREA)
  • Computer Networks & Wireless Communication (AREA)
  • Signal Processing (AREA)
  • Information Transfer Between Computers (AREA)

Abstract

内容传送网络(CDN)中的节点接收对内容的请求并确定关于该请求的信息。当确定了关于内容的足够信息时,将该请求分配给合适的CD服务以处理该请求;以及当没有确定关于内容的足够信息时,将该请求分配给通用CD服务以处理该请求。通用CD服务处理该请求;以及提供关于内容的更新信息,以用于处理将来的请求。对请求进行处理的合适的CD服务也可以提供关于内容的更新信息,以用于处理将来的请求。

Description

内容传送框架中的请求处理
相关申请交叉引用
本专利合作条约(PCT)专利申请要求2014年12月15日提交的题为“REQUESTPROCESSING IN A CONTENT DELIVERY NETWORK”的非临时申请14/570,743的优先权,其全部内容通过引用并入本文。
版权声明
本专利文档包含受版权保护的材料。版权所有者不反对复制本专利文档或美国专利商标局的档案中的任何相关资料,但另保留所有版权。
通过引用并入
以下美国专利和美国公开专利申请通过引用全部并入本文以用于所有目的:
1. 2012年12月12日提交的题为“Content Delivery Network”的美国公开专利申请US2013/0159472;
2. 2012年12月12日提交的题为“Content Delivery Network”的美国公开专利申请US2013/0159473;
3. 2014年6月17日提交的题为“Origin Server-Side Channel In A ContentDelivery Framework”的美国公开专利申请US2014/0344 399;
4. 1998年2月10日提交的题为“Optimized Network Resource Location”的美国专利6,185,598;
5. 2011年9月6日发布的、2009年2月23日提交的题为“Load-B alancingCluster”的美国专利8,015,298;以及
6. 2013年7月16日发布的、2010年9月13日提交的题为“Load-BalancingCluster”的美国专利8,489,750。
技术领域
本发明涉及内容传送和内容传送网络,更具体地说,涉及内容传送网络中的请求处理。
附图说明
本发明的其它目的、特征和特性以及结构的相关元件的操作方法和功能以及部件和制造经济的组合将在参考附图考虑以下描述和所附权利要求的情况下变得更加明显,所有附图构成本说明书的一部分。
图1示出了根据本发明的示例性实施例的示例性内容传送框架的多个方面;
图2(A)-2(B)示出了根据本发明的示例性实施例的示例性内容传送网络(CDN)的多个方面;
图3(A)-3(B)是示出了根据本发明的示例性实施例的处理的多个方面的流程图;以及
图4描绘了根据本发明的示例性实施例的计算的多个方面。
具体实施方式
术语表
如本文所用的,除非另有所用,否则以下术语或缩写具有以下含义:
CD表示内容传送;
CDN表示内容传送网络;
DNS表示域名系统;
HTTP表示超文本传输协议;
HTTPS表示安全版HTTP;
URI表示统一资源标识符;以及
URL表示统一资源定位符。
背景和概述
内容传送网络(CDN)代表一个或更多个内容提供商,优选地经由公共互联网将内容(例如,资源)有效地分发给客户端。内容提供商经由源数据源(源服务器或起源)提供其内容(例如,资源),并且CDN还可以提供一种超高层(over-the-top)传输机制,用于在相反方向上,即从客户端到源服务器有效地发送内容。终端用户(客户端)和内容提供商均受益于使用CDN。通过使用CDN,内容提供商能够使其自己的服务器(例如,其源服务器)减轻压力(从而减轻负载)。客户端通过能够以较少的延迟获得内容而受益。
在2012年12月12日提交的美国公开专利申请US2013/0159472和US/2013/0159473、2014年6月17日提交的US2014/0344399以及1998年2月10日提交的美国专利6,185,598中描述了示例性CDN,每篇文献的全部内容通过引用完整并入本文以用于所有目的。
如本文所使用的,客户端是例如被终端用户用于在系统内发出请求(例如,包括HTTPS请求的DNS和HTTP请求)的代理(例如,浏览器、机顶盒或其它应用)。当不使用CDN或其它中介时,这种请求可以直接转到订户自己的服务器(例如,他们的源服务器)或者互联网中的其它组件。当内容提供商订阅CD服务时(例如,如美国公开专利申请US2013/0159472和US2013/0159473所述),各种请求可以转到中介CD服务,所述中介CD服务可以将终端用户请求映射到源请求,从而沿途可转换和缓存内容。
每个不同的源(例如,源服务器)通常与一个订户相关联,但是订户可以与任何数量的源(包括订户自有的源和CDN提供的源)相关联。
实际上,CDN所交互的物理源可以是从中介链获取内容的中介,可能是例如最终终止于订户的实际源服务器处的独立内容获取系统的元件。然而,就CDN的内部而言,源是从其直接获取内容的系统边界之外的服务。
如本文所使用的,终端用户是最终消费由服务提供商实体提供的一些互联网服务(例如,网站、流媒体服务等)的实体(例如,个人或组织)。在本说明书中,该提供商实体有时被称为订户,因为它们订阅CDN服务,以便有效地传送它们的内容,例如,从其源传送给其消费者。CDN可以提供其订户和它们的最终用户之间的增值媒介(例如,缓存、转换等)。
CDN中的请求处理
这里参照图1描述内容传送框架100的示例性操作方面。客户端102(包括例如客户端1 102-1、客户端2 102-2、...、客户端k 102-k)经由代表一个或更多个订户提供内容的CDN 104来请求内容。应当理解,客户端通常并且优选地不知道它们的请求正被CDN处理。用于特定内容(C)的特定客户端请求(R)被引导到CDN中的CD服务以处理该请求。客户端请求可以通过作为CDN的一部分的会合(rendezvous)机制或以任何已知的方式被引导到CD服务。如图1所示,请求(R)被引导到代理(也称为分片器,slicer)106。从客户端的角度来看,代理106正在处理请求。然而,代理106可以是到可以处理客户端请求的多个其它CD服务(例如,服务器)的前端。如图1所示,代理106可以选择父代108之一来处理客户端请求(R)。代理106可以是交换机等。
应当理解,代理106可以修改和/或增强其从客户端接收的请求(例如,其可以将URL标准化)。为此,从客户端到代理的请求表示为R,而从代理到父代的请求表示为R’。类似地,从父代到源的请求表示为R”。在许多情况下,R可以与R’相同,R’可以与R”相同。类似地,由源提供给父代的内容C可以在被提供给客户端之前被修改和/或增强,因此符号C’表示从父代到客户端的响应5。在许多情况下,C可以与C’相同,并且不需要任何修改。内容的修改可以包括添加元数据、重新格式化等。
优选地,所选择的父代CD服务是适合于给出的请求类型的服务。例如,一些CD服务可以以使得它们有效用于提供大型资源的方式被配置或调整,而其它CD服务可以被配置或调整为在提供小型资源方面更有效。节点的调整/配置可以包括:其拥有多少物理内存,其磁盘驱动器的数量/大小,其是否有旋转驱动器或固态驱动器(SSD)以及其上正在运行的软件。本领域普通技术人员将在阅读本说明书后认识到并理解,这些属性进行组合以指定特定机器或CDN节点最适合服务于哪种资源。例如,具有大量旋转驱动器但没有太多内存的机器会非常适合于提供可以从磁盘流出的非常大的资源。相反,对于大量但不太热门的小型资源的资料库,机器将希望拥有大量的SSD,以便访问它们的时间足够快。具有大量物理内存的机器则可以很好地处理大型或小型资源的工作集,相比需要前往磁盘,这些大型或小型资源的工作集更有效地适应内存。具有强大CPU性能的机器则对于需要大量操作(例如,擦写(scrubbing)、边侧包含(edge-side-include)或其它“边缘应用(applieation at theedge)”处理)的资源而言更为优先。
通常,代理106知道所请求的内容越多,其父代CD服务的选择应越好(更合适)。在这方面,代理106可以查询一个或更多个属性数据库110来确定与所请求的内容(例如,资源)有关的属性。属性数据库110优选地提供诸如资源大小的属性。在本文的优选示例性实施例中,客户端请求是采用URI或URL形式的HTTP请求(包括HTTPS请求),并且属性数据库110可以使用URL来进行索引。如本文所使用的,用于特定请求的合适的CD服务可以是被充分配置(例如,利用硬件和/或软件)以处理该特定请求的CD服务。应当理解,尽管其它CD服务可能能够处理特定请求,但是合适的CD服务将优选地以有效的方式来处理该特定请求(或者,至少与其它CD服务一样有效)。
如上所述,代理106选择合适的父代CD服务(例如,服务器)来处理客户端请求。所选择的CD服务(例如,父代服务器)可以可行地经由代理分片器106将所请求的内容(R)提供给请求客户端。在一些情况下,所选择的CD服务可以从另一位置(例如,与内容提供商相关联的源服务器112)获得所请求的内容。如上所述,代理用作接触点,其基于正被请求的特定内容(例如,资源)将请求转发到合适的后端机器。也就是说,代理可以接收所有内容请求,但是向被调整为用于大型资源的那些机器发送针对大型资源的填充请求,并且向被调整为用于小型资源的那些机器发送针对小型资源的填充请求(或者,无论对机器的调整是什么标准映射)。
现在参照图2(A)描述请求处理的多个方面,图2(A)是代理106没有足够的(或任何)信息来将请求分配给合适的父代服务器的情况。客户端102做出内容请求R(在图2(A)中的A1处)。请求R被引导到代理106,代理106在属性数据库110中查找关于请求R的信息(在202处)。在该情况下,数据库110中没有足够的信息来允许代理106做出合适的确定。具体地,在一些实现中,代理106可能没有关于与请求R相关联的内容的大小的信息。然后,代理106将请求R发送/分配给通用(或任意)的父代CD服务108-G(在A2处)。
如本文所使用的,通用CD服务是指可能能够处理请求R的任何CD服务,尽管该通用服务可能并不适合或最适合处理该请求。
父代CD服务108-G请求与请求R相关联的内容(在A3处)(例如,从合适的源服务112),然后将所请求的内容C提供给请求客户端(可能经由代理106)(在A4-A5处)。父代CD服务108-G还跟踪和维护关于内容C的信息,优选地包括内容C的大小。然后,父代CD服务108-G可以用关于内容C的信息更新属性数据库110(在204处)。在一些情况下,父代CD服务108-G还可以(或替代地)在C的头部(header)中提供关于内容C的一些属性。
当代理106接收到先前已被处理的内容请求时,关于C的信息可能已经在数据库110中。如现在参照图2(B)所示,客户端102做出请求R(在B1处)。该请求被引导到代理106,代理106确定关于与R相关联的内容C的信息。例如,代理106可以查询数据库110(在202’处)以获得关于内容C的属性数据(例如,内容C的大小)。由于在该情况下代理106具有足够的信息,所以它将请求R’分配给合适的CD服务(例如,父代#A 108-A)(在B2处)。CD服务108-A对请求进行处理(在B3处),从而将所请求的内容C提供给请求客户端(可能经由代理106)。
注意,对请求进行处理的CD服务108-A可以访问和/或更新属性数据库110,以例如添加关于内容C的热门程度的信息。
参照图3(A)-3(B)中的示例性流程图,描述各种实体做出的处理的多个方面。参照图3(A)的流程图,其示出了代理106所做出的处理的多个方面,代理106获得对内容(C)的请求(R)(在302处)。代理106确定(在304处)其是否具有关于所请求的内容C的足够信息(例如,C的大小或热门程度)。代理106可以访问一个或更多个数据库来确定关于内容C的信息。如果代理106没有并且不能确定关于内容C的足够信息来将请求分配给合适的CD服务(例如,父代服务器),则(在308处)代理106将请求R发送给通用CD服务(G)(例如,通用父代服务器)。另一方面,如果代理106确定(在304处)其确实具有(或可以确定)关于所请求的内容C的足够信息来将请求分配给合适的CD服务,则(在306处)代理106可以将请求发送给合适的CD服务(例如,服务器)。
参照图3(B)的流程图,其示出了通用服务器(G)(例如,在308处从代理106接收到请求的通用服务器)所做出的处理的多个方面,通用服务器(G)获得对内容C的请求R(在310处)。在这种情况下,请求到达服务器G,因为代理106没有关于内容C的足够信息来选择合适的服务器。然而,仍然可能有这种情况,通用服务器G具有或知道关于内容C的信息。如果通用服务器G知道关于内容C的信息或具有副本,则在属性数据库中更新关于C的信息。通用服务器C例如从源服务器获得所请求的内容(C)的副本(在312处),然后将内容C提供给请求客户端(在314处)。然后,通用服务器更新属性数据库(在316处),以包括其已经确定的关于内容C的信息(例如,内容的大小)。如果需要,通用服务器还可以(或者替代地)将元数据附加到响应,以指示资源类别。当下一次在该代理分片器接收到对该资源的请求时,可以利用缓存的元数据将填充请求引导到合适的父代主机。如果下一请求到达了不同的分片器,则其可能会联系同一个通用父代主机,该通用父代主机可以将其重定向到合适的父代主机。应当理解,当请求由合适的服务器处理时(在306发送的),该合适的服务器还可以更新属性数据库以包括它确定的关于内容C的信息。类似地,该合适的服务器还可以(或者替代地)将元数据附加到响应,以指示资源类别。
应该理解,在资源到期时,CDN可能需要重新学习资源。为此,优选地,对请求进行处理的CD服务基于关于资源的当前信息来更新数据库(或使它们被更新)。
由此描述了一种系统,其中CDN可以在其看到请求时确定请求的类别。CDN可以学习内容(例如,资源),并可以在其看到资源请求时,学习每个资源将落入什么类别,并合适地进行适配。
计算
图4是实现可以用于执行本文讨论的处理的代理、父代服务器或其它计算设备的计算系统400的示意图。该计算系统包括总线402(即互连)、至少一个处理器404、至少一个通信端口414、主存储器406、可移除存储介质410、只读存储器408以及大容量存储设备412。处理器404可以是任何已知的处理器,例如但不限于: 处理器、处理器或处理器产品线。通信端口414可以是用于基于调制解调器的拨号连接的RS-232端口、10/100以太网端口、使用铜缆或光纤的千兆端口或USB端口中的任何一个。可以根据计算机系统所连接到的诸如局域网(LAN)、广域网(WAN)或任何网络之类的网络来选择通信端口414。服务器可以经由输入/输出(I/O)端口420与外围设备(例如,显示屏416、输入设备418)通信。
主存储器406可以是随机存取存储器(RAM)或本领域公知的任何其它动态存储设备。只读存储器408可以是任何静态存储设备,例如用于存储静态信息(诸如处理器404的指令)的可编程只读存储器(PROM)芯片。大容量存储设备412可以用于存储信息和指令。例如,可以使用诸如系列的小型计算机串行接口(SCSI)驱动器之类的硬盘、光盘、诸如独立磁盘冗余阵列(RAID)、诸如系列的RAID驱动器之类的磁盘阵列或者任何其它大容量存储设备。
总线402将处理器404与其它存储器、存储设备和通信模块通信地耦接。根据所使用的存储设备,总线402可以是PCI/PCI-X、SCSI或基于通用串行总线(USB)的系统总线(或其它总线)。可移除存储介质410可以是任何种类的外部硬盘驱动器、软盘驱动器、Zip驱动器、致密盘-只读存储器(CD-ROM)、致密盘可重写(CD-RW)、数字视频盘-只读存储器(DVD-ROM)等。
本文中的实施例可以被提供为计算机程序产品,其可以包括其上存储有指令的机器可读介质,所述指令可以用于对计算机(或其它电子设备)进行编程以执行处理。机器可读介质可以包括但不限于软盘、光盘、CD-ROM、磁光盘、ROM、RAM、可擦除可编程只读存储器(EPROM)、电可擦除可编程只读存储器(EEPROM)、磁卡或光卡、闪存或适用于存储电子指令的其它类型的介质/机器可读介质。
如图所示,主存储器可以被编码有一个或更多个应用/服务422,所述应用/服务支持如上面关于各种附图和其它所讨论的功能。例如,在一个实施例中,应用422可以包括或以其它方式实现本文所描述的各种处理和/或指令。应用422(和/或如本文所述的其它资源)可以被实现为支持根据本文所述的不同实施例的处理功能的软件代码,例如,数据和/或逻辑指令(例如,存储在存储器中或另一计算机可读介质例如磁盘上的代码)。在一个实施例的操作期间,处理器404通过使用总线402访问主存储器406,以启动、运行、执行、解释或以其它方式执行应用422的逻辑指令。应用422的执行产生应用进程424中的处理功能。换句话说,进程424表示在计算机系统400中的处理器404内或之上执行的应用422的一个或更多个部分。
以上描述包括体现本公开技术的示例性系统、方法、技术、指令序列和/或计算机程序产品。然而,应当理解,可以在没有这些具体细节的情况下实施本公开。在本公开中,所公开的方法可以被实现为设备可读的指令集或软件。此外,应当理解,所公开的方法中的步骤的具体顺序或层次是示例方法的例子。基于设计偏好,应当理解,方法中的步骤的具体顺序或层次可以被重新排列,同时仍然在所公开的主题范围之内。随附的方法权利要求以样本顺序呈现各个步骤的元素,并且不一定意味着受限于所呈现的具体顺序或层次。
结论
如本文所使用的,包括在权利要求中,短语“至少一些”是指“一个或更多个”,并且包括仅一个的情况。因此,例如,短语“至少一些服务”是指“一个或更多个服务”,并且包括一个服务的情况。
如本文所使用的,包括在权利要求中,短语“基于”是指“部分地基于”或“至少部分地基于”,而不是排他性的。因此,例如,短语“基于因子X”是指“部分地基于因子X”或“至少部分地基于因子X”。除非使用单词“仅仅”明确说明,否则短语“基于X”并不意味着“仅基于X”。
如本文所使用的,包括在权利要求中,短语“使用”是指“至少使用”,而不是排他性的。因此,例如,短语“使用X”表示“至少使用X”。除非使用单词“仅仅”明确说明,否则短语“使用X”并不意味着“仅使用X”。
通常,如本文所使用的,包括在权利要求中,除非在短语中具体使用单词“仅”,否则不应将其读入该短语中。
如本文所使用的,包括在权利要求中,短语“不同”是指“至少部分不同”。除非明确规定,否则不同并不意味着完全不同。因此,例如,短语“X不同于Y”表示“X至少部分不同于Y”,并不意味着“X与Y完全不同”。因此,如本文所使用的,包括在权利要求中,短语“X不同于Y”表示X至少以某种方式与Y不同。
如本文所使用的,包括在权利要求中,列表可以仅包括一个项目,并且除非另有说明,否则不需要以任何特定方式对多个项目的列表进行排序。列表可以包括重复的项目。例如,如本文所使用的,短语“CDN服务的列表”可以包括一个或更多个CDN服务。
应当理解,说明书和权利要求中的词语“第一”和“第二”用于区分或识别,而不是表明序列或数字限制。类似地,使用字母或数字标签(例如“(a)”、“(b)”等)用于帮助区分和/或识别,而不表示任何序列或数字限制或排序。
除非另有明确说明,否则任何流程图中的任何标签框不暗示排序。当图中显示断开的框时,与这些框相关联的活动可以以任何顺序执行,包括完全并行或部分并行。
虽然已经结合当前认为最实际和优选的实施例来描述了本发明,但是应该理解本发明不限于所公开的实施例,相反,本发明旨在覆盖所附权利要求的精神和范围内所包括的各种修改和等同布置。

Claims (21)

1.一种能够利用内容传送网络CDN操作的计算机实现的方法,所述方法包括:
由CDN中的节点进行以下操作,
(A)接收对内容的请求;
(B)确定关于所述请求的信息;
(C)基于(B)中的所述确定,
(C)(1)当确定了关于所述内容的足够信息时,将所述请求分配给合适的CD服务以处理所述请求;以及
(C)(2)当没有确定关于所述内容的足够信息时,将所述请求分配给通用CD服务以处理所述请求;以及
(D)当所述请求在(C)(2)中被分配给所述通用CD服务时,则所述通用CD服务:
(D)(1)处理所述请求;以及
(D)(2)提供关于所述内容的更新信息。
2.根据权利要求1所述的方法,其中,从缓存CD服务中选择所述合适的CD服务和所述通用CD服务。
3.根据权利要求1所述的方法,其中,所述请求是对资源的HTTP请求。
4.根据权利要求3所述的方法,其中,关于所述内容的足够信息包括内容的大小。
5.根据权利要求1所述的方法,其中,所述请求包括URI或URL,并且其中(B)中确定关于所述请求的信息包括:访问从URL到关于与所述请求相关联的内容的信息的映射。
6.根据权利要求5所述的方法,其中,所述URL对应于特定资源,并且其中关于所述特定资源的信息包括所述特定资源的大小。
7.根据权利要求5所述的方法,其中,(D)(2)中提供关于所述内容的更新信息包括:更新所述映射。
8.根据权利要求7所述的方法,其中,所述映射保持在一个或更多个数据库中。
9.根据权利要求1所述的方法,还包括:
(E)当所述请求在(C)(1)中被分配给所述合适的CD服务时,则所述合适的CD服务:
(E)(1)处理所述请求;以及
(E)(2)提供关于所述内容的更新信息。
10.一种能够利用内容传送网络CDN操作的计算机实现的方法,所述方法包括:
由CDN中的节点进行以下操作,
(A)接收对内容的请求;
(B)确定所述内容的类别;
(C)基于(B)中的所述确定,
(C)(1)当确定了所述内容的类别时,基于所述内容的类别,将所述请求分配给合适的CD服务以处理所述请求;以及
(C)(2)当没有确定所述内容的类别时,将所述请求分配给通用CD服务以处理所述请求;以及
(D)当所述请求在(C)(2)中被分配给所述通用CD服务时,则所述通用CD服务:
(D)(1)处理所述请求;以及
(D)(2)提供所述内容的类别。
11.根据权利要求10所述的方法,其中,所述内容的类别基于内容的大小。
12.根据权利要求11所述的方法,其中,所述请求是HTTP请求,并且其中所述内容包括一个或更多个资源。
13.一种在非暂时性计算机可读介质上存储有计算机可读指令的计算机程序产品,所述计算机可读指令包括用于实现计算机实现的方法的指令,所述方法能够操作在具有包括存储器和至少一个处理器在内的硬件并在所述硬件上运行服务的设备上,所述方法能够在内容传送服务CDN中操作,所述方法包括:由CDN中的节点进行以下操作:
(A)接收对内容的请求;
(B)确定关于所述请求的信息;
(C)基于(B)中的所述确定,
(C)(1)当确定了关于所述内容的足够信息时,将所述请求分配给合适的CD服务以处理所述请求;以及
(C)(2)当没有确定关于所述内容的足够信息时,将所述请求分配给通用CD服务以处理所述请求;以及
(D)当所述请求在(C)(2)中被分配给所述通用CD服务时,则所述通用CD服务:
(D)(1)处理所述请求;以及
(D)(2)提供关于所述内容的更新信息。
14.根据权利要求13所述的计算机程序产品,其中,从缓存CD服务中选择所述合适的CD服务和所述通用CD服务。
15.根据权利要求13所述的计算机程序产品,其中,所述请求是对资源的HTTP请求。
16.根据权利要求15所述的计算机程序产品,其中,关于所述内容的足够信息包括内容的大小。
17.根据权利要求13所述的计算机程序产品,其中,所述请求包括URI或URL,并且其中(B)中确定关于所述请求的信息包括:访问从URL到关于与所述请求相关联的内容的信息的映射。
18.根据权利要求17所述的计算机程序产品,其中,所述URL对应于特定资源,并且其中关于所述特定资源的信息包括所述特定资源的大小。
19.根据权利要求17所述的计算机程序产品,其中,(D)(2)中提供关于所述内容的更新信息包括:更新所述映射。
20.根据权利要求19所述的计算机程序产品,其中,所述映射保持在一个或更多个数据库中。
21.根据权利要求13所述的计算机程序产品,还包括:
(E)当所述请求在(C)(1)中被分配给所述合适的CD服务时,则所述合适的CD服务:
(E)(1)处理所述请求;以及
(E)(2)提供关于所述内容的更新信息。
CN201580068160.2A 2014-12-15 2015-12-15 利用内容传送网络cdn操作的方法和计算机可读介质 Active CN107003980B (zh)

Applications Claiming Priority (3)

Application Number Priority Date Filing Date Title
US14/570,743 2014-12-15
US14/570,743 US10841400B2 (en) 2014-12-15 2014-12-15 Request processing in a content delivery framework
PCT/US2015/065835 WO2016100351A1 (en) 2014-12-15 2015-12-15 Request processing in a content delivery framework

Publications (2)

Publication Number Publication Date
CN107003980A true CN107003980A (zh) 2017-08-01
CN107003980B CN107003980B (zh) 2020-10-30

Family

ID=56112351

Family Applications (1)

Application Number Title Priority Date Filing Date
CN201580068160.2A Active CN107003980B (zh) 2014-12-15 2015-12-15 利用内容传送网络cdn操作的方法和计算机可读介质

Country Status (8)

Country Link
US (3) US10841400B2 (zh)
EP (1) EP3234795A4 (zh)
JP (1) JP6693670B2 (zh)
CN (1) CN107003980B (zh)
CA (1) CA2970538A1 (zh)
HK (1) HK1244911A1 (zh)
SG (1) SG11201704606XA (zh)
WO (1) WO2016100351A1 (zh)

Families Citing this family (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US10841400B2 (en) * 2014-12-15 2020-11-17 Level 3 Communications, Llc Request processing in a content delivery framework
WO2017023236A1 (en) * 2015-07-31 2017-02-09 Hewlett Packard Enterprise Development Lp Proxy-controlled compartmentalized database access
US9866996B1 (en) * 2016-07-07 2018-01-09 Estimote Polska Sp. Z O. O. Method and system for content delivery with a beacon

Citations (9)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6278992B1 (en) * 1997-03-19 2001-08-21 John Andrew Curtis Search engine using indexing method for storing and retrieving data
US20120023090A1 (en) * 2010-04-01 2012-01-26 Lee Hahn Holloway Methods and apparatuses for providing internet-based proxy services
US20120023530A1 (en) * 2009-04-10 2012-01-26 Zte Corporation Content location method and content delivery network node
US20120198043A1 (en) * 2011-01-12 2012-08-02 Level 3 Communications, Llc Customized domain names in a content delivery network (cdn)
US20120324108A1 (en) * 2011-06-15 2012-12-20 Juniper Networks, Inc. Network integrated dynamic resource routing
WO2013005758A1 (ja) * 2011-07-05 2013-01-10 日本電気株式会社 コンテンツ配信システムおよびコンテンツ配信方法
US20140173018A1 (en) * 2012-12-13 2014-06-19 Futurewei Technologies, Inc. Content Based Traffic Engineering in Software Defined Information Centric Networks
US8799372B1 (en) * 2008-10-07 2014-08-05 Sprint Spectrum, L.P. Management of referenced object based on size of referenced object
US20140286165A1 (en) * 2013-03-25 2014-09-25 Altiostar Networks, Inc. Optimization of a Backhaul Connection in a Mobile Communications Network

Family Cites Families (19)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
EP1402412A2 (en) * 2000-12-23 2004-03-31 International Business Machines Corporation Distributing information in a markup language within a computer system
US7054910B1 (en) * 2001-12-20 2006-05-30 Emc Corporation Data replication facility for distributed computing environments
JP2004086317A (ja) 2002-08-23 2004-03-18 Fujitsu Ltd 負荷分散方法及び装置
FI20045077A (fi) * 2004-03-16 2005-09-17 Nokia Corp Menetelmä ja laitteisto viestin kokorajoituksen indikoimiseksi
US8166031B2 (en) * 2007-05-04 2012-04-24 Redknee Inc. System and method for providing context based services
US8180720B1 (en) * 2007-07-19 2012-05-15 Akamai Technologies, Inc. Content delivery network (CDN) cold content handling
US8145222B2 (en) * 2007-10-02 2012-03-27 Research In Motion Limited Method, mobile communication device, and system for selective downloading to a mobile communication device
WO2010033938A2 (en) * 2008-09-19 2010-03-25 Limelight Networks, Inc. Content delivery network stream server vignette distribution
US20100082808A1 (en) * 2008-09-29 2010-04-01 Red Aril, Inc. System and method for automatically delivering relevant internet content
US8719351B2 (en) * 2009-09-15 2014-05-06 International Business Machines Corporation Image rescale based on defined characteristics
US9148332B2 (en) * 2010-05-19 2015-09-29 Google Inc. Content delivery network
US9559868B2 (en) * 2011-04-01 2017-01-31 Onavo Mobile Ltd. Apparatus and methods for bandwidth saving and on-demand data delivery for a mobile device
US20130311614A1 (en) * 2012-05-21 2013-11-21 Motorola Mobility, Inc. Method for retrieving content and wireless communication device for performing same
US9426049B1 (en) * 2013-01-07 2016-08-23 Zettics, Inc. Domain name resolution
US9794375B2 (en) * 2013-03-14 2017-10-17 Openwave Mobility, Inc. Method, apparatus, and non-transitory computer medium for obtaining a required frame size for a compressed data frame
US20150105043A1 (en) * 2013-10-15 2015-04-16 Opera Software Ireland Limited Pro-Active Mobile Network Data Usage Alert System
US10009439B1 (en) * 2013-12-05 2018-06-26 Instart Logic, Inc. Cache preloading
US9729663B2 (en) * 2014-09-29 2017-08-08 Limelight Networks, Inc. Dynamic/shared PMTU cache
US10841400B2 (en) 2014-12-15 2020-11-17 Level 3 Communications, Llc Request processing in a content delivery framework

Patent Citations (9)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6278992B1 (en) * 1997-03-19 2001-08-21 John Andrew Curtis Search engine using indexing method for storing and retrieving data
US8799372B1 (en) * 2008-10-07 2014-08-05 Sprint Spectrum, L.P. Management of referenced object based on size of referenced object
US20120023530A1 (en) * 2009-04-10 2012-01-26 Zte Corporation Content location method and content delivery network node
US20120023090A1 (en) * 2010-04-01 2012-01-26 Lee Hahn Holloway Methods and apparatuses for providing internet-based proxy services
US20120198043A1 (en) * 2011-01-12 2012-08-02 Level 3 Communications, Llc Customized domain names in a content delivery network (cdn)
US20120324108A1 (en) * 2011-06-15 2012-12-20 Juniper Networks, Inc. Network integrated dynamic resource routing
WO2013005758A1 (ja) * 2011-07-05 2013-01-10 日本電気株式会社 コンテンツ配信システムおよびコンテンツ配信方法
US20140173018A1 (en) * 2012-12-13 2014-06-19 Futurewei Technologies, Inc. Content Based Traffic Engineering in Software Defined Information Centric Networks
US20140286165A1 (en) * 2013-03-25 2014-09-25 Altiostar Networks, Inc. Optimization of a Backhaul Connection in a Mobile Communications Network

Also Published As

Publication number Publication date
US20210067606A1 (en) 2021-03-04
US20230239376A1 (en) 2023-07-27
US20160173643A1 (en) 2016-06-16
HK1244911A1 (zh) 2018-08-17
EP3234795A4 (en) 2018-06-13
US11575773B2 (en) 2023-02-07
JP2018500671A (ja) 2018-01-11
JP6693670B2 (ja) 2020-05-13
US10841400B2 (en) 2020-11-17
WO2016100351A1 (en) 2016-06-23
CN107003980B (zh) 2020-10-30
CA2970538A1 (en) 2016-06-23
SG11201704606XA (en) 2017-07-28
EP3234795A1 (en) 2017-10-25

Similar Documents

Publication Publication Date Title
AU2016200352B2 (en) Method and system to provide video-based search results
US11375044B2 (en) Custom digital components
US10482477B2 (en) Stratified sampling applied to A/B tests
AU2010221620B2 (en) Content rendering on a computer
US8359313B2 (en) Extensible custom variables for tracking user traffic
US10742763B2 (en) Data limit aware content rendering
CN107111636A (zh) 用于顺序传输优化存储装置的卷级冗余编码技术
US11755608B2 (en) Interactive dataflow preview
US10885085B2 (en) System to organize search and display unstructured data
US11575773B2 (en) Request processing in a content delivery framework
JP2023164813A (ja) 強化されたオンラインプライバシ
US8554999B2 (en) Methods for providing a response and systems thereof
WO2017096836A1 (zh) 视频文件的缓存方法和系统
US20140244633A1 (en) Relevance-weighted attribute sorting apparatus and method
CN104956360B (zh) 利用数据uri增强的渐进图像呈现
DK2572271T3 (en) Progressive graphical representation
CN111355766B (zh) Pdf文件在网络上按需加载的渲染方法
CN105827580B (zh) 页面访问方法、装置及系统
CN112016017A (zh) 确定特征数据的方法和装置
JP2007108992A (ja) トランザクション分散方法、トランザクション分散プログラムおよびトランザクション分散装置
CN117336536A (zh) 一种直播方法、计算设备及存储介质
CN116610827A (zh) 自动生成演示文稿的方法和装置、管理演示文稿的系统
Mwiti Optimization of bandwidth using by use of a proxy server
CN111414367A (zh) 获取参数的方法和装置
US20150215377A1 (en) Efficient Transfer of an Application

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