Search Images Maps Play YouTube News Gmail Drive More »
Sign in
Screen reader users: click this link for accessible mode. Accessible mode has the same essential features but works better with your reader.

Patents

  1. Advanced Patent Search
Publication numberUS20030079027 A1
Publication typeApplication
Application numberUS 09/982,721
Publication dateApr 24, 2003
Filing dateOct 18, 2001
Priority dateOct 18, 2001
Also published asUS9021112, US20080235400
Publication number09982721, 982721, US 2003/0079027 A1, US 2003/079027 A1, US 20030079027 A1, US 20030079027A1, US 2003079027 A1, US 2003079027A1, US-A1-20030079027, US-A1-2003079027, US2003/0079027A1, US2003/079027A1, US20030079027 A1, US20030079027A1, US2003079027 A1, US2003079027A1
InventorsMichael Slocombe, Matthew Miller, Casey Ajalat, Vincent Fuller
Original AssigneeMichael Slocombe, Matthew Miller, Casey Ajalat, Fuller Vincent A.
Export CitationBiBTeX, EndNote, RefMan
External Links: USPTO, USPTO Assignment, Espacenet
Content request routing and load balancing for content distribution networks
US 20030079027 A1
Abstract
A content distribution mechanism that distributes content of a content provider at various sites across a network and selects the site that is nearest a content requestor using an anycast address that resides at each of the sites. The sites are configured as nodes (or clusters) and each node includes a content server and a DNS server. The DNS servers are so associated with the content servers at their respective nodes as to resolve the name of the content provider to the IP address of the content servers at the nodes. The DNS servers each are assigned the anycast address in addition to a unique address, and the anycast address is advertised to the network (in particular, the network routing infrastructure) using Border Gateway Protocol (BGP). Node selection occurs when the network routing infrastructure selects a shortest path to the anycast address during DNS name resolution.
Images(6)
Previous page
Next page
Claims(11)
What is claimed is:
1. A method of content delivery in a network, comprising:
associating devices in a Domain Name System (DNS) with content server systems located in the network, the content server systems maintaining and serving content of a content provider, each DNS device configured to resolve the name of the content provider to an address for the content server system with which such DNS device is associated; and
assigning to the DNS devices a common address, the common address being usable to resolve the name of the content provider such that a request for content of the content provider by a content requestor is sent to the content server system nearest the content requestor.
2. The method of claim 1, wherein the common address is an anycast address.
3. The method of claim 2, wherein routing information associated with the anycast address is advertised over the network by the DNS devices in accordance with the Border Gateway Protocol (BGP).
4. The method of claim 1, wherein the content server systems are geographically distributed across the network.
5. The method of claim 1, wherein the DNS devices are collocated with the content server systems with which the DNS devices are associated.
6. The method of claim 1, wherein each content server system and associated DNS device are located in a different Internet Service Provider Point of Presence.
7. The method of claim 1, wherein each content server system and associated DNS device is located at or near an entry point of the network.
8. The method of claim 1, where the content server systems comprise cache systems that cache content of the content provider.
9. The method of claim 8, wherein at least one of the cache systems comprises at least two cache servers connected in a cluster, and wherein the at least two cache servers are coupled to a switch usable to select from among the at least two cache servers based on a selection policy.
10. A computer program product residing on a computer-readable medium for managing a content delivery network, the computer program product comprising instructions causing a computer to:
maintain content server systems at different locations in the network to store content of a content provider and serve content to a content requester;
configure Domain Name System (DNS) devices to resolve a name of the content provider to an address for a corresponding one of the content server systems; and
assign to each of the DNS devices a common address, the common address being usable to allow a content request intended for the content provider to be sent to the content server system nearest the content requestor.
11. A content distribution system comprising:
content distribution nodes connected to a content provider, a content provider Domain Name System (DNS) server and a content requestor DNS server via the Internet, each content distribution node including a DNS server coupled to and associated with a content server system, the content server system operating to store content originating with the content provider and serve content to a content requester, and each DNS server being assigned an address common to all of the DNS servers in the content distribution nodes;
the common address being provided by the content provider DNS server to the content requestor DNS server in response to a DNS request from the content requestor DNS server, thereby enabling the content requestor DNS server to use the Internet to select a path to the content distribution node nearest the content requestor and forward the DNS request to the selected node; and
the DNS server in the selected node being configured to resolve the name of the content provider in the DNS request to an IP address of the associated content server system and cause the IP address to be returned to the content requester.
Description
    BACKGROUND
  • [0001]
    The invention relates generally to information retrieval in a network and, more particularly, to hosting and distributing content on a content delivery network such as the Internet.
  • [0002]
    The World Wide Web is the Internet's content retrieval system. In the Web environment, client systems effect transactions to Web servers using the Hypertext Transfer Protocol (HTTP), which provides clients with access to files (e.g., text, graphics, images, sound, video, etc.) using a standard page description language, for example, Hypertext Markup Language (HTML). A network path to a server is identified by a so-called Uniform Resource Locator (URL) having a special syntax for defining a network connection. Use of a Web browser at a client (end user) system involves specification of a link via the URL. In response, the client system makes a request to the server (sometimes referred to as a “Web site”) identified in the link and, in return, receives content from the Web server. The Web server can return different content data object types, such as .gif and jpeg files (graphics), .mpeg files (video), .wav files (audio) and the like.
  • [0003]
    As the Web server content provided by World Wide Web has continued to grow over time, so too has the number of users demanding access to such content. Unfortunately, the ever-increasing number of end users requesting Web content from Web sites has resulted in serious bandwidth and latency issues, which manifest themselves in delay to the end user.
  • [0004]
    To address these problems, many networking product and service providers have developed solutions that distribute Web site content across the network in some manner. One class of solutions involves replicating Web servers at multiple locations and directing traffic (by modifying the URL and forwarding, or using HTTP re-direct) to the “best” server based on a predefined selection policy, e.g., load balancing, network topology. Another class of solutions distributes content strategically and/or geographically, and often uses some type of centralized or hierarchical Domain Name System (DNS)-based site selection. The distributed sites include servers that perform reverse proxy with (or without) caching. One such technique routes traffic to a content distribution site nearest the requestor by modifying URLs in the top-level Web page. Other DNS techniques use a round robin traffic distribution to distribute load to the content sites, but do not take into account the location of the requester relative to those content sites.
  • SUMMARY
  • [0005]
    In one aspect, the invention provides a method of content delivery in a network. The method includes associating devices in a Domain Name System (DNS) with content server systems located in the network, the content server systems maintaining and serving content of a content provider, each DNS device configured to resolve the name of the content provider to an address for the content server system with which such DNS device is associated. The method further includes assigning to the DNS devices a common address, the common address being usable to resolve the name of the content provider such that a request for content of the content provider by a content requestor is sent to the content server system nearest the content requestor.
  • [0006]
    Particular implementations of the invention may provide one or more of the following advantages.
  • [0007]
    A performance benefit is gained because a content requestor can generally retrieve content from a content site closer than the origin server of the content provider. In addition, because there are multiple sites serving the content, the load from many end users is distributed among multiple systems and across different parts of the network. Also, an end user's DNS request can be routed to a content site nearest the requestor using pre-existing routing infrastructure. Because DNS uses a stateless protocol (UDP) for routing, the solution can handle anycast addressable caching without the problems associated with anycast service, namely, the protential packet-by packet load balancing site effects of protocols like TCP which maintain state information.
  • [0008]
    Other features and advantages of the invention will be apparent from the following detailed description and from the claims.
  • DESCRIPTION OF DRAWINGS
  • [0009]
    [0009]FIG. 1 is a depiction of a prior Web transaction.
  • [0010]
    [0010]FIG. 2 is a depiction of a prior Web transaction using reverse-proxy caching.
  • [0011]
    [0011]FIG. 3 is a block diagram of an exemplary content distribution network which includes content distribution nodes that support reverse-proxy caching and anycast address service to achieve distributed content delivery and load balancing.
  • [0012]
    [0012]FIG. 4 is a simplified block diagram of routing configuration software and associated table(s) (provided in the routing infrastructure of the content distribution network of FIG. 3) used to perform distributed content site selection based on anycast address routing and Border Gateway Protocol (BGP).
  • [0013]
    [0013]FIG. 5 is a depiction of an exemplary Web transaction using the content distribution network shown in FIG. 3.
  • [0014]
    Like reference numbers will be used to represent like elements.
  • DETAILED DESCRIPTION
  • [0015]
    The present invention features a content distribution mechanism for routing a content request to the nearest content distribution site in a content distribution network. It also provides for load sharing across multiple content distribution sites in a content distribution network. The content distribution mechanism has particular utility in and is therefore described within the context of an Internet-based, World Wide Web (“Web”) network infrastructure.
  • [0016]
    Hereinafter, the following terminology is used:
  • [0017]
    “Content provider” refers to an entity having a Web site on a network. Generally, the entity produces the content for the Web site. The entity may operate a Web server system or may use the services of a hosting provider.
  • [0018]
    “End user” refers to a person who wishes to view the Web content. Typically, an end user uses a Web browser, such as Netscape Navigator or Internet Explorer, executing on a computer system, e.g., a personal computer.
  • [0019]
    “Domain Name System” (DNS) refers to a collection of systems available on the public Internet that can resolve a domain name to a specific Internet Protocol (IP) address, as is known in the art.
  • [0020]
    It will be understood that reference to distance on the network, such as one server being “closer” to an end user than another server, refers to a network distance. Thus, a shorter distance implies a better path based on network criteria, and not necessarily a shorter geographic distance.
  • [0021]
    In the description to follow, a fictitious company “ABCD” is used as an example of a content provider having a Web site on a network.
  • [0022]
    [0022]FIG. 1 shows a conventional content delivery Web transaction 10. The transaction 10 involves a Web server 12 (also referred to as an “origin server”), an authoritative DNS system 14, an end-user system 16 and an end-user DNS system 18, all of which are coupled to a network 20, for example, the public Internet. The Web server 12 is a computer system containing content (e.g., Web pages) for a content provider, with the ability to provide this content in response to a Web request via the HTTP protocol. The authoritative DNS system 14 is a DNS system that can resolve domain names within the content provider's namespace.
  • [0023]
    For example, the DNS system 14 for the company “ABCD” would have information for host names ending in “.abcd.com” (such as “www.abcd.com”). Typically, the end-user system 16 is a computer being operated by an end user to perform Web “browsing” (that is, view Web pages). The end-user DNS system 18 is a DNS server that the end-user system 16 uses to resolve domain names to IP addresses.
  • [0024]
    When the end user wishes to view a Web page or object (such as “www.abcd.com/PriceList”), the transaction 10 occurs as follows. First, the end user using the end user system 16 enters the name of a Web page into a browser (not shown) executing on the end user system 16. The end-user system 16 requests a DNS resolution for the host name (“www.abcd.com”) from the end-user DNS system 18 (“DNS Req 22”). The end-user DNS system 18 determines which of the DNS systems that make up the DNS for the network 20 can resolve this host name by sending a DNS request to the authoritative DNS system 14 (“DNS Req 24”). The authoritative DNS system 14 resolves the name to an IP address and returns a response containing the IP address to the end-user 16 system via the end-user DNS system 18 (“DNS Resp 26”). The end-user DNS system 18, in turn, communicates the IP address to the end-user station 16 in a DNS response to the end-user system 16 (“DNS Resp 27”). The end-user system 16 contacts the Web server 12 at the specified IP address and requests the Web object (“www.abcd.comlPriceList”) (“HTTP Req 28”). The Web server 12 returns the Web page corresponding to the requested Web object to the end-user system 16 (“HTTP Resp” 30). The browser running on the end-user station 16 displays the returned Web page on the end-user system 16 for viewing by the end user.
  • [0025]
    [0025]FIG. 2 illustrates a Web transaction with reverse proxy caching 40. That is, the transaction 40 is the same basic Web transaction as shown in FIG. 1, but now employs a reverse proxy content server (shown as a cache server) 42 acting on behalf of the Web server 12. During reverse-proxy caching, the cache server 42 assumes the identity of the Web server 12 so that a Web request directed to the Web server 12 (in the example, “www.abcd.com”) is instead directed to the cache server 42. This re-direction is accomplished by changing the entry for the Web site (“www.abcd.com”) in the authoritative DNS system 14 so that the host name resolves to the address of the cache server 42 instead of the address of the original Web server 12. A new name is assigned to the address of the original Web server 12 (e.g., “origin.abcd.com”). Thus, 22, 24, 26 and 27 are the same as in FIG. 1. However, the IP address returned by the authoritative DNS system 14 is that of the cache server 42, not the Web server itself, as was previously described with reference to FIG. 1. Consequently, instead of sending the subsequent content request to and receiving a response from the Web server 12 (as was shown in steps 28 and 30 of FIG. 1), the end-user system 16 sends the content request to the cache server 22 (“HTTP Req 44”) and the cache server 22 fetches the requested content from the Web server (“HTTP Req 46”). The Web server 12 returns the requested content to the cache server 42 (“HTTP Resp 48”). The cache server 42 completes the transaction by serving the requested content to the end-user system 16 (“HTTP Resp 50”) and caching the content so the content will be readily available to support future requests for the same content (“store”52).
  • [0026]
    [0026]FIG. 3 shows a content distribution network (“CDN”) 60. The CDN 60 includes at least one Web server, shown as a Web server 62, a DNS system 64 for Web server 62, and end-user stations 66 a and 66 b, all connected to a network 72. The network 72 is implemented as the public Internet. The end-user stations execute Web browsers 68 a and 68 b, respectively. Each end-user station 66 has an associated end user DNS, however, only an end user DNS 70 a for the end-user station 66 a is shown. Of course, additional end-user stations may be connected to the network 72. Also connected to the network 72 are multiple content distribution nodes 76 a, 76 b and 76 c, which support distributed content delivery services for one or more Web sites on the network 72. The CDN nodes 76 interact with the origin server 62 containing the original Web content, the various DNS systems 64, 70 and, of course, the end-user systems 66.
  • [0027]
    Each of the CDN nodes 76 includes a DNS system 78 coupled to and associated with a Web content server system or site 80. In one embodiment, as described herein, each content server system 80 is implemented as a cache server system. The techniques described herein could also apply to other types of content servers, such as mirrored Web content servers, or Web content servers having different content (e.g., customized for geographic area). Each DNS system 78 in each node holds a table that includes an address entry which the DNS system 78 uses to map the domain name of the content provider to the IP address of the cache server in that same node. Although only one such Web site (Web site 62) is shown, it will be appreciated that other Web sites may be connected to the network 72 and use the DNS and content caching services of the nodes 76, as will be described. The nodes 76 are deployed at different locations in the network 72. Preferably, the nodes 76 are geographically distributed across the network 72.
  • [0028]
    Optionally, the CDN 60 may include a CDN manager 82 that can be used by a network administrator (for example, a CDN node hardware and/or CDN node service provider) to configure the CDN to use the CDN nodes.
  • [0029]
    The network 72 is intended to represent a simplified view of the Internet. In the simplified depiction of FIG. 3, the network 72 includes a plurality of interconnected routers or routing networks, e.g., routers 74 a. 74 b, . . . , 74 g, for routing packets from one domain to another within network 60. In actuality, the Internet is made up of many private “routing networks” (networks including one or more routers, and possibly other types of networking components as well), e.g., local, regional and centralized Internet Service Providers (ISPs), some of which are connected to Network Access Points (NAPs) or exchanges, or each other at public or private peering points. In the simplified Internet configuration shown in FIG. 3, routers 74 a, 74 b, 74 c 74 d and 74 e are located at network entry points. The end user station 66 a and end user DNS system 70 a connect to the network 72 via the router 74 a. The end user station 66 b is coupled to another router 74 i, which connects to the router 74 d. The Web Server 62 and associated DNS system 64 are connected to the network 72 via the router 74 b. Preferably, to the extent possible, and for reasons which will be discussed below, the end user DNS systems such as system 70 a are located near the end user systems with which they are associated.
  • [0030]
    Also, preferably, the geographically dispersed nodes 76 are located so as to be as close as possible to various network entry points, exchanges or both. The network entry points each may correspond to an ISP Point of Presence (POP). In FIG. 3, for illustrative purposes, the nodes 76 a, 76 b and 76 c are shown as being connected to entry point routers 74 c, 74 b and 74 d, respectively, but need not be directly connected to network access routers in this manner.
  • [0031]
    The caching servers 80 have unique IP addresses. The DNS systems 78 share a common IP address as well as have unique IP addresses. The end-user DNS systems, e.g., end user DNS system 70 a, resolve to the common address. That is, the end-user DNS system 70 a knows which DNS system (in this example, the DNS system 64) has an address for a high level domain server, e.g., .com, org, and maintains tables of all domain names and knows which server (authoritative DNS server) to consult for the address of the domain server. Thus, the address lookup table in the DNS system 64 is configured to indicate that a server corresponding to the common address can resolve the domain name of the content provider to an IP address.
  • [0032]
    One way to implement this content distribution configuration is to use an anycast address as the common address. An anycast address is a unicast address that is used in multiple places. Various Internet Engineering Task Force (IETF) Internet Requests for Comments (RFCs) describe implementations of anycast addresses in IP networks. The IETF is a large open international community of network designers, operators, vendors, and researchers concerned with the evolution of the Internet architecture and the smooth operation of the Internet. The following anycast-related RFCs are hereby incorporated by reference in their entirety for all purposes: RFC 1546 (November 1993); RFC 2372 (July 1998); RFC 2373 (August 1998); and RFC 2526 (March 1999).
  • [0033]
    As described in RFC 1546, an anycast address may include a subnet prefix identifier and an anycast identifier. The subnet prefix may be used to specify the network providing the anycast addresses. The anycast identifier is used to specify one of many possible anycast addresses on a particular subnet. A unicast address, or conventional IP address, specifies a single interface on a computer network. In contrast, an anycast address may specify more than one interface. For example, anycast addresses may be used to specify a group of one or more servers on a computer network. These servers may provide a redundant service. Routers forward packets destined to anycast addresses to the closest anycast destination for a particular address. Thus, anycast addresses provide a way to distribute load across one or more servers
  • [0034]
    The anycast address is advertised to the network 72 from each node 76 using a dynamic routing protocol, the Border Gateway Protocol (BGP). The BGP is a routing protocol used to exchange network reachability information between Internet border routers. It enables those routers to make intelligent routing decisions as to the best path. The BGP is used by such routers as their exterior routing protocol in order to advertise routes to other border routers. BGP uses TCP as its transport protocol for exchanging routing information. Adjacent routers running BGP set up a TCP connection to exchange entire routing tables. Each router has enough information to determine an optimal next hop to a destination. The BGP is also described in various RFCs, including RFC 1267 (October 1991) and RFC 1654 (July 1994), incorporated herein by reference.
  • [0035]
    Referring to FIG. 4, routing configuration support 90 in a router such as router 74 b includes a routing algorithm (software) 94 and a routing table 92. The router 74 b receives address path information from the nodes 76 in accordance with the BGP route information exchanges and updates 96, including the anycast address 98 and associated paths 100 for each of the nodes, and stores them in the routing table 92. As a result of the BGP table information exchanges and updates, routers in the network 72 maintain pointers (that is, the paths or routes) that allow it to determine the next hop to every unique address in the network, as well as multiple pointers to the anycast address. The routing algorithm 94, in response to receipt of a DNS request packet 102 from an end-user system 66 for resolution of a DNS name for the content provider, uses the path information 100 stored in the routing table 92 to a select a path to the nearest CDN node. Thus, a router may see multiple connections to the anycast address, but selects the path that represents the shortest network distance (e.g, the topologically shortest path). More specifically, as this routing occurs as part of a DNS resolution, the router selects a route to the closest DNS system 78. Because the selected DNS system resolves to the address of the cache server in the DNS system's node, the DNS anycast routing, in essence, serves to select the local content site (cache) from which content will be served.
  • [0036]
    Referring now to FIG. 5, a Web transaction 90 occurring over a CDN (such as the CDN 60 shown in FIG. 3) is illustrated for the running example of the “ABCD” Web site. To provide content distribution service for this site, the following configurations are implemented. The original Web server 62 is renamed in the DNS system 64 to reflect a change in its role from being the primary Web server to becoming the original content source for the cache servers 80. The domain “www.abcd.com” is renamed “origin.abcd.com”. In the end-user DNS system 70 a, an entry is made to indicate that the CDN DNS system 78 is the authoritative server for the end user web domain. For example, in the dns.abcd.com system, the entry for “www.abcd.com” no longer resolves to a specific address but instead refers the content requestor to the CDN DNS server 78 at the anycast address of 4.2.2.19. The CDN DNS server entry resolves to the address of the associated node's caching server 80. As a result, each node 76 resolves the Web site name to a different address. In the above example, DNS server 78 a in node 76 a (node 1) resolves the name “www.abcd.com” to 10.3.15.1, whereas in node 76 b (node 2), the DNS server 78 b resolves the same address to 10.3.15.2. In this manner, therefore, the entry made in the CDN DNS server 78 in each node enables distribution of the Web site among the cache servers 80 in their respective nodes and locations, as will be described in further detail below.
  • [0037]
    Once the appropriate configurations have been completed, it is assumed that the Web site www.abcd.com is being handled by the CDN nodes 76. Each node 76 advertises the anycast address of its own DNS server 78 to the network 72 using the BPG protocol, as discussed above. The address of the DNS server at each node is identical. That is, from a network point of view, the network “thinks” it is connected to a single host at multiple points.
  • [0038]
    Referring to FIGS. 3 and 5, the Web transaction operation 90 is as follows. When an end user of the end-user station 66 a requests an object from the now “accelerated” Web site, the end-user system 66 a first resolves the content provider name via DNS. That is, the end-user station (acting as a content requestor) sends a request to the local DNS server 70 a (“DNS Req 92”). That server 70 a resolves the name, ultimately by sending a request to the CDN DNS anycast address. The DNS server 70 a sends a request to the ABCD DNS server 64 (“DNS Req 94”), which returns the anycast address of the CDN nodes 76 to the requesting DNS server 70 a (DNS Resp 96). The DNS server 70 a then transmits a DNS name resolution request addressed to the anycast address and that request is generally routed (by various ones of the network routers 74 a-74 h) to the CDN node nearest the user's DNS system (“DNS Req 96”). In this instance, because the request enters the network via the router 74 b, the router 74 b determines that the shortest path to the anycast address is the path to the node 76 b (node 2). At that node, the DNS server 78 b resolves the name to the cache server address for that node, that is, IP address 10.3.15.2 assigned to the cache server 80 b, and returns the cache server address to the end-user DNS server 70 a (“DNS Resp 98”). The end-user DNS server 70 a forwards the address to the end-user system 66 a (“DNS Resp 100). From this point on, the remaining steps of the transaction are much the same as steps 44 through 52, shown in FIG. 2. That is, the end-user system 70 a requests the Web object from the cache server in the nearby node where the DNS name was resolved, i.e., node 76 b, and that node's cache server 80 b, in turn, checks for a cached version of the object (if cached content already resides on the cache server). If no content has yet been cached in the server, or the cached copy is stale or otherwise invalid, the cache server 80 b retrieves the Web object from the origin server 62, and serves the object to the end-user system that requested it.
  • [0039]
    Typically, as is known in the art, Web content can be marked with certain caching attributes, for example, whether or not the content is at all cacheable, how long the content may be held in cache. In the case of the former attribute, if the content is marked as uncacheable (e.g., dynamic or content containing sensitive information), the cache server discards the content after serving it to the requestor. Otherwise, if the content is cacheable, the cache server will store the content in local storage and maintain the cached content according to any other cache attributes. Content can be localized, for example, using ad insertions with local content. Content in the caches can be pre-loaded (all the cache servers receiving the same content). That is, the content can be replicated on all cache servers so that even the first request will have a fast response time. Preferably, the caches are not preloaded with content but instead build their cached content based on user requests/usage over time. Content is retrieved from the origin server 12 when a first user request is received, and then stored locally. If subsequent requests are received for the same content, the cached copy is used if it is still valid, as was mentioned earlier. Thus, the cache server need not retrieve the content from the origin server again. Each cache server contains a translation table so that it knows where to retrieve any particular Web page from the origin server. For example, the cache server 80 b would know that the page “www.abcd.com/PriceList” can be retrieved from “origin.abcd.com/PriceList”.
  • [0040]
    Preferably, the CDN node contains software to monitor the load in various parts of the node cache system (disk, CPU, I/O, et cetera) by determining at least one load metric value (based on metrics such as utilization, latency, etc.) and comparing each such metric value to a predefined overload threshold. Upon reaching a predefined overload threshold, the monitoring software informs the routing software in the CDN DNS server to withdraw its BGP routing advertisement.
  • [0041]
    Thus, under normal conditions, all CDN nodes are advertising the address of their DNS servers to the network, and so a DNS request will be directed to the nearest CDN node. If a node becomes heavily loaded and detects an overload condition through its internal monitoring, the node stops advertising its DNS address to the network so that no further requests will be directed to that node. Consequently, DNS requests that normally would have been routed to that node as a first choice are routed to the next closest active node.
  • [0042]
    This overload detection and load balancing mechanism has the advantage that Web transactions already in progress are not interrupted by a shift in resources. Any system that has already resolved a DNS name to the now inactive node will continue using that node until the DNS name expires. The load in that node will slowly decrease until such time as the node can start accepting new clients, at which time it will start advertising its DNS system address to the network again.
  • [0043]
    Other embodiments are contemplated. For example, it is possible to use an anycast scheme with the cache servers themselves. With reference to the system shown in FIG. 3, the network routing directs the DNS request from the end user's DNS system, such as system 70 a, to the closest of the CDN nodes 76. Although the node is the node closest to the end user's DNS system, it may not necessarily be the closest to the end-user system. In those cases where the end user's DNS system is a substantial distance from the end user, it is possible that the end user system will use a CDN node that is not the closest one to the end user system. Allowing the cache servers to use a common address would ensure that the end user's Web request is indeed routed to the nearest CDN node. There is a significant drawback associated with using the anycast-addressable cache server approach, however. The client/server portion of the transaction uses the TCP protocol, thus requiring multiple exchanges between the end user and the cache server to complete a transaction. With anycasting, there is no guarantee that subsequent packets in a transaction will be routed to the same server. In cases where the packets are split between two or more cache servers, a successful transaction cannot occur. In contrast, although requiring that the end user DNS system be located in close proximity to the end user system for optimal CDN performance, the anycast-based DNS resolution is completed using a single packet exchange with the stateless UDP protocol, thus eliminating the packet-by-packet load distribution problem seen with TCP.
  • [0044]
    In addition, the Web caches, i.e., the cache systems 80 each can be implemented to include multiple caches servers connected, for example, in a cluster configuration. There may be multiple servers available to support one customer (origin server) or, alternatively, one or more cache servers available to support multiple customers' content cached at one node (site). In yet another alternative, the cache server clusters can include a switch to select from among the cache servers in a given node/cluster based on a predetermined selection policy, for example, content-aware selection (which enables the clustered servers store different content, and maps requested objects to the appropriate servers), load balancing, and so forth, using known techniques.
  • [0045]
    Other embodiments are within the scope of the following claims.
Patent Citations
Cited PatentFiling datePublication dateApplicantTitle
US4495570 *Jan 7, 1982Jan 22, 1985Hitachi, Ltd.Processing request allocator for assignment of loads in a distributed processing system
US4726017 *May 21, 1985Feb 16, 1988Fla.Multidrop data concentrator communication network
US4803641 *Nov 25, 1987Feb 7, 1989Tecknowledge, Inc.Basic expert system tool
US4920432 *Jan 12, 1988Apr 24, 1990Eggers Derek CSystem for random access to an audio video data library with independent selection and display at each of a plurality of remote locations
US5191573 *Sep 18, 1990Mar 2, 1993Hair Arthur RMethod for transmitting a desired digital video or audio signal
US5287499 *May 16, 1991Feb 15, 1994Bell Communications Research, Inc.Methods and apparatus for information storage and retrieval utilizing a method of hashing and different collision avoidance schemes depending upon clustering in the hash table
US5287537 *Sep 21, 1992Feb 15, 1994Data General CorporationDistributed processing system having plural computers each using identical retaining information to identify another computer for executing a received command
US5291554 *Aug 19, 1992Mar 1, 1994Tv Answer, Inc.Shared-price custom video rentals via interactive TV
US5410343 *Apr 2, 1993Apr 25, 1995Bell Atlantic Network Services, Inc.Video-on-demand services using public switched telephone network
US5508732 *Mar 22, 1993Apr 16, 1996International Business Machines CorporationData server, control server and gateway architecture system and method for broadcasting digital video on demand
US5592611 *Mar 14, 1995Jan 7, 1997Network Integrity, Inc.Stand-in computer server
US5594910 *Nov 26, 1993Jan 14, 1997Ibm Corp.Interactive computer network and method of operation
US5603026 *Dec 7, 1994Feb 11, 1997Xerox CorporationApplication-specific conflict resolution for weakly consistent replicated databases
US5619648 *Nov 30, 1994Apr 8, 1997Lucent Technologies Inc.Message filtering techniques
US5623656 *Dec 15, 1994Apr 22, 1997Lucent Technologies Inc.Script-based data communication system and method utilizing state memory
US5625781 *Oct 31, 1995Apr 29, 1997International Business Machines CorporationItinerary list for interfaces
US5712979 *Sep 20, 1995Jan 27, 1998Infonautics CorporationMethod and apparatus for attaching navigational history information to universal resource locator links on a world wide web page
US5715453 *May 31, 1996Feb 3, 1998International Business Machines CorporationWeb server mechanism for processing function calls for dynamic data queries in a web page
US5721914 *Sep 14, 1995Feb 24, 1998Mci CorporationSystem and method for hierarchical data distribution
US5734831 *Apr 26, 1996Mar 31, 1998Sun Microsystems, Inc.System for configuring and remotely administering a unix computer over a network
US5740423 *Dec 28, 1995Apr 14, 1998Csg Systems, Inc.System and method for accessing distributed data on a plurality of databases
US5742762 *May 19, 1995Apr 21, 1998Telogy Networks, Inc.Network management gateway
US5856974 *Feb 13, 1996Jan 5, 1999Novell, Inc.Internetwork address mapping gateway
US5862339 *Jul 9, 1996Jan 19, 1999Webtv Networks, Inc.Client connects to an internet access provider using algorithm downloaded from a central server based upon client's desired criteria after disconnected from the server
US5867706 *Dec 19, 1996Feb 2, 1999International Business Machines Corp.Method of load balancing across the processors of a server
US5867799 *Apr 4, 1996Feb 2, 1999Lang; Andrew K.Information system and method for filtering a massive flow of information entities to meet user information classification needs
US5870546 *Dec 23, 1997Feb 9, 1999Infoseek CorporationMethod and apparatus for redirection of server external hyper-link reference
US5870559 *Apr 11, 1997Feb 9, 1999Mercury InteractiveSoftware system and associated methods for facilitating the analysis and management of web sites
US5878212 *Jul 31, 1995Mar 2, 1999At&T Corp.System for updating mapping or virtual host names to layer-3 address when multimedia server changes its usage state to busy or not busy
US5884038 *May 2, 1997Mar 16, 1999Whowhere? Inc.Method for providing an Internet protocol address with a domain name server
US5890171 *Aug 6, 1996Mar 30, 1999Microsoft CorporationComputer system and computer-implemented method for interpreting hypertext links in a document when including the document within another document
US5893116 *Sep 30, 1996Apr 6, 1999Novell, Inc.Accessing network resources using network resource replicator and captured login script for use when the computer is disconnected from the network
US5894554 *Apr 23, 1996Apr 13, 1999Infospinner, Inc.System for managing dynamic web page generation requests by intercepting request at web server and routing to page server thereby releasing web server to process other requests
US5896533 *Jul 6, 1995Apr 20, 1999Intel CorporationAccessing internets world-wide web through object linking and embedding technology
US6012090 *Mar 14, 1997Jan 4, 2000At&T Corp.Client-side parallel requests for network services using group name association
US6014686 *Jun 20, 1997Jan 11, 2000Telcordia Technologies, Inc.Apparatus and methods for highly available directory services in the distributed computing environment
US6014698 *Jun 11, 1997Jan 11, 2000Matchlogic, Inc.System using first banner request that can not be blocked from reaching a server for accurately counting displays of banners on network terminals
US6018516 *Nov 14, 1997Jan 25, 2000Packeteer, Inc.Method for minimizing unneeded retransmission of packets in a packet communication environment supporting a plurality of data link rates
US6026440 *Jan 27, 1997Feb 15, 2000International Business Machines CorporationWeb server account manager plug-in for monitoring resources
US6029175 *Jun 7, 1996Feb 22, 2000Teknowledge CorporationAutomatic retrieval of changed files by a network software agent
US6029176 *Nov 25, 1997Feb 22, 2000Cannon Holdings, L.L.C.Manipulating and analyzing data using a computer system having a database mining engine resides in memory
US6035332 *Oct 6, 1997Mar 7, 2000Ncr CorporationMethod for monitoring user interactions with web pages from web server using data and command lists for maintaining information visited and issued by participants
US6038216 *Nov 1, 1996Mar 14, 2000Packeteer, Inc.Method for explicit data rate control in a packet communication environment without data rate supervision
US6038310 *Aug 1, 1995Mar 14, 2000British Telecommunications Public Limited CompanyService node for a telephony network
US6038610 *Jul 17, 1996Mar 14, 2000Microsoft CorporationStorage of sitemaps at server sites for holding information regarding content
US6041324 *Nov 17, 1997Mar 21, 2000International Business Machines CorporationSystem and method for identifying valid portion of computer resource identifier
US6044405 *Apr 12, 1996Mar 28, 2000Wam!Net Inc.Service network incorporating geographically-remote hubs linked by high speed transmission paths
US6046980 *Nov 24, 1997Apr 4, 2000Packeteer, Inc.System for managing flow bandwidth utilization at network, transport and application layers in store and forward network
US6049830 *May 13, 1997Apr 11, 2000Sony CorporationPeripheral software download of a broadcast receiver
US6052718 *Jan 7, 1997Apr 18, 2000Sightpath, IncReplica routing
US6052730 *Jan 9, 1998Apr 18, 2000The Board Of Trustees Of The Leland Stanford Junior UniversityMethod for monitoring and/or modifying web browsing sessions
US6148410 *Sep 15, 1997Nov 14, 2000International Business Machines CorporationFault tolerant recoverable TCP/IP connection router
US6173311 *Feb 13, 1997Jan 9, 2001Pointcast, Inc.Apparatus, method and article of manufacture for servicing client requests on a network
US6173322 *Jun 5, 1997Jan 9, 2001Silicon Graphics, Inc.Network request distribution based on static rules and dynamic performance data
US6178160 *Dec 23, 1997Jan 23, 2001Cisco Technology, Inc.Load balancing of client connections across a network using server based algorithms
US6181867 *Jun 7, 1995Jan 30, 2001Intervu, Inc.Video storage and retrieval system
US6185598 *Feb 10, 1998Feb 6, 2001Digital Island, Inc.Optimized network resource location
US6185619 *Nov 7, 1997Feb 6, 2001Genuity Inc.Method and apparatus for balancing the process load on network servers according to network and serve based policies
US6189030 *May 1, 1998Feb 13, 2001Infoseek CorporationMethod and apparatus for redirection of server external hyper-link references
US6189039 *Apr 10, 1997Feb 13, 2001International Business Machines CorporationSelective tunneling of streaming data
US6195680 *Jul 23, 1998Feb 27, 2001International Business Machines CorporationClient-based dynamic switching of streaming servers for fault-tolerance and load balancing
US6205120 *Mar 13, 1998Mar 20, 2001Packeteer, Inc.Method for transparently determining and setting an optimal minimum required TCP window size
US6266339 *May 13, 1999Jul 24, 2001Starguide Digital Networks, Inc.High bandwidth broadcast system having localized multicast access to broadcast content
US6338044 *Mar 17, 1999Jan 8, 2002Loudeye Technologies, Inc.Personal digital content system
US6347085 *Aug 14, 1997Feb 12, 2002Netspeak CorporationMethod and apparatus for establishing communications between packet-switched and circuit-switched networks
US6360256 *Jul 1, 1996Mar 19, 2002Sun Microsystems, Inc.Name service for a redundant array of internet servers
US6505248 *Mar 24, 1999Jan 7, 2003Gte Data Services IncorporatedMethod and system for monitoring and dynamically reporting a status of a remote server
US6529477 *Feb 2, 1999Mar 4, 2003Mentat Inc.Internet over satellite system
US6614757 *Nov 23, 1998Sep 2, 20033Com CorporationMethod of local flow control in an asynchronous transfer mode network utilizing PNNI routing protocol
US6687731 *Jun 8, 1998Feb 3, 2004Telia AbArrangement for load sharing in computer networks
US6691148 *Dec 24, 1998Feb 10, 2004Verizon Corporate Services Group Inc.Framework for providing quality of service requirements in a distributed object-oriented computer system
US6694358 *Aug 23, 2000Feb 17, 2004Speedera Networks, Inc.Performance computer network method
US6699418 *Feb 14, 2002Mar 2, 2004Kuraray Co., Ltd.Method for producing biaxially stretched film made of ethylene-vinyl alcohol copolymer
US6708137 *Jul 16, 2001Mar 16, 2004Cable & Wireless Internet Services, Inc.System and method for providing composite variance analysis for network operation
US6711152 *Jul 6, 1999Mar 23, 2004At&T Corp.Routing over large clouds
US6785704 *Jul 3, 2000Aug 31, 2004Fastforward NetworksContent distribution system for operation over an internetwork including content peering arrangements
US6842604 *Oct 12, 2001Jan 11, 2005Loudeye CorporationPersonal digital content system
US6870851 *May 26, 2000Mar 22, 2005Savvis, Inc.Method and system for optimizing routing of data packets
US6874032 *Nov 15, 2001Mar 29, 2005Verizon Laboratories Inc.Method and system for burst congestion control in an internet protocol network
US6996616 *Apr 17, 2001Feb 7, 2006Akamai Technologies, Inc.HTML delivery from edge-of-network servers in a content delivery network (CDN)
US7003572 *Apr 30, 2001Feb 21, 2006Packeteer, Inc.System and method for efficiently forwarding client requests from a proxy server in a TCP/IP computing environment
US7007089 *Jun 6, 2002Feb 28, 2006Akarnai Technologies, Inc.Content delivery network map generation using passive measurement data
US7010578 *Sep 21, 2000Mar 7, 2006Akamai Technologies, Inc.Internet content delivery service with third party cache interface support
US7012900 *Aug 22, 2001Mar 14, 2006Packeteer, Inc.Method for measuring network delay using gap time
US7075897 *Dec 20, 2001Jul 11, 2006Nec CorporationMethod for resolving duplication of terminal identifiers in a wireless communication system
US7181523 *May 18, 2001Feb 20, 2007Intel CorporationMethod and apparatus for managing a plurality of servers in a content delivery network
US7343422 *Apr 26, 2001Mar 11, 2008Adara Networks, Inc.System and method for using uniform resource locators to map application layer content names to network layer anycast addresses
US7653700 *Jan 26, 2010Microsoft CorporationSystem and method for performing client-centric load balancing of multiple globally-dispersed servers
US7808968 *Jan 29, 2004Oct 5, 2010At&T Intellectual Property Ii, L.P.Method for determining non-broadcast multiple access (NBMA) connectivity for routers having multiple local NBMA interfaces
US20020018449 *Jul 27, 2001Feb 14, 2002Digital Island, Inc.On-demand overlay routing for computer-based communication networks
US20020021675 *Jul 18, 2001Feb 21, 2002At&T Corp.System and method for packet network configuration debugging and database
US20020023164 *Jan 29, 2001Feb 21, 2002Lahr Nils B.Method and apparatus for client-side authentication and stream selection in a content distribution system
US20020023165 *Jan 29, 2001Feb 21, 2002Lahr Nils B.Method and apparatus for encoder-based distribution of live video and other streaming content
US20020075836 *Dec 20, 2001Jun 20, 2002Nec CorporationWireless communication system
US20030009444 *Jun 14, 2002Jan 9, 2003Eidler Christopher WilliamSecured shared storage architecture
US20030018966 *Oct 19, 2001Jan 23, 2003Cook David H.System and method for selective insertion of content into streaming media
US20030028623 *Aug 2, 2002Feb 6, 2003Hennessey Wade L.Method and apparatus for facilitating distributed delivery of content across a computer network
US20030028626 *Aug 2, 2002Feb 6, 2003Hennessey Wade L.Dynamically configuring network communication parameters for an application
US20030028777 *Aug 2, 2002Feb 6, 2003Hennessey Wade L.Method and apparatus for facilitating secure distributed content delivery
US20030055972 *Jul 9, 2002Mar 20, 2003Fuller William TracyMethods and systems for shared storage virtualization
US20030061263 *Sep 26, 2001Mar 27, 2003Guy RiddleDynamic partitioning of network resources
US20030061280 *Sep 24, 2002Mar 27, 2003Bulson Jason AndrewSystems and methods for enhancing streaming media
US20040022194 *Jul 30, 2003Feb 5, 2004Digital Island, Inc.On-demand overlay routing for computer-based communication networks
US20040249960 *Mar 12, 2002Dec 9, 2004Hardy William GeoffreyAccess networks
US20050010653 *Aug 5, 2004Jan 13, 2005Fastforward Networks, Inc.Content distribution system for operation over an internetwork including content peering arrangements
US20050033858 *Aug 31, 2004Feb 10, 2005Swildens Eric Sven-JohanLoad balancing service
US20050038851 *Sep 21, 2004Feb 17, 2005Xcelera, A Delaware CorporationWeb serving system
US20080235400 *Mar 18, 2008Sep 25, 2008Level 3 Communications, LlcContent request routing and load balancing for content distribution networks
Referenced by
Citing PatentFiling datePublication dateApplicantTitle
US7257628 *Jun 23, 2003Aug 14, 2007Cisco Technology, Inc.Methods and apparatus for performing content distribution in a content distribution network
US7373394 *Jun 30, 2003May 13, 2008Cisco Technology, Inc.Method and apparatus for multicast cloud with integrated multicast and unicast channel routing in a content distribution network
US7409439 *Dec 9, 2002Aug 5, 2008Sun Microsystems Inc.Reducing overhead in reverse proxy servers when processing web pages
US7565423 *Jun 30, 2004Jul 21, 2009Google Inc.System and method of accessing a document efficiently through multi-tier web caching
US7590119 *Mar 14, 2005Sep 15, 2009Cisco Technology, Inc.Method and apparatus for context-based prefix updates in border gateway protocol
US7664864 *Feb 16, 2010Verisign, Inc.Meta content distribution network
US7756065 *Jul 13, 2010Samsung Electronics Co., Ltd.Domain name service system and method thereof
US7839415Nov 23, 2010Verisign, Inc.Method and system for improved internet color
US7925785Apr 12, 2011Microsoft CorporationOn-demand capacity management
US7962631Jun 14, 2011Yahoo! Inc.Method for determining network proximity for global traffic load balancing using passive TCP performance instrumentation
US8065275Feb 15, 2007Nov 22, 2011Google Inc.Systems and methods for cache optimization
US8170010 *Jan 8, 2006May 1, 2012Panasonic CorporationMultiple interface mobile node with simultaneous home- and foreign network connection
US8199752Apr 26, 2010Jun 12, 2012Limelight Networks, Inc.Enhanced anycast for edge server selection
US8224964Jul 17, 2012Google Inc.System and method of accessing a document efficiently through multi-tier web caching
US8250175 *Aug 2, 2006Aug 21, 2012Cisco Technology, Inc.Techniques for remapping content requests
US8270403Sep 27, 2011Sep 18, 2012Limelight Networks, Inc.Enhanced Anycast for edge server selection
US8275790Oct 14, 2008Sep 25, 2012Google Inc.System and method of accessing a document efficiently through multi-tier web caching
US8291083Dec 23, 2011Oct 16, 2012Limelight Networks, Inc.Distributed landing pad and brick topology for content storage in content delivery networks
US8345060Jan 1, 2013Verisign, Inc.Method and system for improved internet color
US8396970Dec 23, 2011Mar 12, 2013Limelight Networks, Inc.Content processing between locations workflow in content delivery networks
US8452874 *Nov 22, 2010May 28, 2013Amazon Technologies, Inc.Request routing processing
US8458290Dec 30, 2011Jun 4, 2013Limelight Networks, Inc.Multicast mapped look-up on content delivery networks
US8478858Jan 5, 2012Jul 2, 2013Limelight Networks, Inc.Policy management for content storage in content delivery networks
US8495220Sep 15, 2012Jul 23, 2013Amazon Technologies, Inc.Managing CDN registration by a storage provider
US8510448Sep 13, 2012Aug 13, 2013Amazon Technologies, Inc.Service provider registration by a content broker
US8520663Feb 26, 2008Aug 27, 2013At&T Intellectual Property I, L. P.Systems and methods to select peered border elements for an IP multimedia session based on quality-of-service
US8521813Dec 23, 2011Aug 27, 2013Limelight Networks, Inc.Content replication workflow in content delivery networks
US8521851Mar 27, 2009Aug 27, 2013Amazon Technologies, Inc.DNS query processing using resource identifiers specifying an application broker
US8521885Sep 15, 2012Aug 27, 2013Amazon Technologies, Inc.Dynamically translating resource identifiers for request routing using popularity information
US8533293Mar 31, 2008Sep 10, 2013Amazon Technologies, Inc.Client side cache management
US8539099 *Jan 8, 2010Sep 17, 2013Alcatel LucentMethod for providing on-path content distribution
US8543702Sep 15, 2012Sep 24, 2013Amazon Technologies, Inc.Managing resources using resource expiration data
US8553689Apr 3, 2012Oct 8, 2013Panasonic CorporationHome agent acting as a proxy for a Mobile Node
US8560597Oct 16, 2009Oct 15, 2013At&T Intellectual Property I, L.P.Anycast transport protocol for content distribution networks
US8560598Dec 22, 2009Oct 15, 2013At&T Intellectual Property I, L.P.Integrated adaptive anycast for content distribution
US8577992Sep 28, 2010Nov 5, 2013Amazon Technologies, Inc.Request routing management based on network components
US8583776Aug 6, 2012Nov 12, 2013Amazon Technologies, Inc.Managing content delivery network service providers
US8601090Mar 31, 2008Dec 3, 2013Amazon Technologies, Inc.Network resource identification
US8606996Mar 31, 2008Dec 10, 2013Amazon Technologies, Inc.Cache optimization
US8607014Dec 22, 2009Dec 10, 2013At&T Intellectual Property I, L.P.Multi-autonomous system anycast content delivery network
US8612622Apr 26, 2010Dec 17, 2013Limelight Networks, Inc.Real-time message queuing for a processing ring
US8615577Dec 23, 2011Dec 24, 2013Limelight Networks, Inc.Policy based processing of content objects in a content delivery network using mutators
US8626950 *Dec 3, 2010Jan 7, 2014Amazon Technologies, Inc.Request routing processing
US8639742Jul 16, 2012Jan 28, 2014Google Inc.Refreshing cached documents and storing differential document content
US8639817Dec 19, 2012Jan 28, 2014Amazon Technologies, Inc.Content management
US8676918Sep 15, 2012Mar 18, 2014Amazon Technologies, Inc.Point of presence management in request routing
US8676922Jun 30, 2004Mar 18, 2014Google Inc.Automatic proxy setting modification
US8688837Mar 27, 2009Apr 1, 2014Amazon Technologies, Inc.Dynamically translating resource identifiers for request routing using popularity information
US8713156Feb 13, 2013Apr 29, 2014Amazon Technologies, Inc.Request routing based on class
US8732309Nov 17, 2008May 20, 2014Amazon Technologies, Inc.Request routing utilizing cost information
US8745240 *Apr 11, 2012Jun 3, 2014Edgecast Networks, Inc.Global load balancing on a content delivery network
US8756325Mar 11, 2013Jun 17, 2014Amazon Technologies, Inc.Content management
US8756340Dec 20, 2007Jun 17, 2014Yahoo! Inc.DNS wildcard beaconing to determine client location and resolver load for global traffic load balancing
US8756341Mar 27, 2009Jun 17, 2014Amazon Technologies, Inc.Request routing utilizing popularity information
US8762535 *Jan 24, 2012Jun 24, 2014BitGravity, Inc.Managing TCP anycast requests
US8782236Jun 16, 2009Jul 15, 2014Amazon Technologies, Inc.Managing resources using resource expiration data
US8788475Jun 28, 2012Jul 22, 2014Google Inc.System and method of accessing a document efficiently through multi-tier web caching
US8788671Jan 25, 2012Jul 22, 2014Amazon Technologies, Inc.Managing content delivery network service providers by a content broker
US8812651Feb 15, 2007Aug 19, 2014Google Inc.Systems and methods for client cache awareness
US8819283Sep 28, 2010Aug 26, 2014Amazon Technologies, Inc.Request routing in a networked environment
US8825754Jul 16, 2012Sep 2, 2014Google Inc.Prioritized preloading of documents to client
US8838802 *Oct 26, 2007Sep 16, 2014At&T Intellectual Property Ii, L.P.Proximity routing for session based applications using anycast
US8856281Mar 22, 2010Oct 7, 2014At&T Intellectual Property I, L.P.Internet protocol version 6 content routing
US8856329Mar 22, 2013Oct 7, 2014Limelight Networks, Inc.Multicast mapped look-up on content delivery networks
US8924466Oct 30, 2007Dec 30, 2014Level 3 Communications, LlcServer handoff in content delivery network
US8924528Sep 28, 2010Dec 30, 2014Amazon Technologies, Inc.Latency measurement in resource requests
US8930513Sep 28, 2010Jan 6, 2015Amazon Technologies, Inc.Latency measurement in resource requests
US8930538Mar 21, 2009Jan 6, 2015Level 3 Communications, LlcHandling long-tail content in a content delivery network (CDN)
US8930544Oct 29, 2013Jan 6, 2015Amazon Technologies, Inc.Network resource identification
US8938526Sep 28, 2010Jan 20, 2015Amazon Technologies, Inc.Request routing management based on network components
US8943193 *Apr 4, 2012Jan 27, 2015Marlow Technologies, LLC.Unified web hosting and content distribution system and method for assuring predetermined performance levels
US8948050 *Aug 23, 2012Feb 3, 2015Fujitsu LimitedDistribution system, distribution method, and memory medium thereof
US8954548Aug 27, 2008Feb 10, 2015At&T Intellectual Property Ii, L.P.Targeted caching to reduce bandwidth consumption
US8966033Aug 17, 2009Feb 24, 2015At&T Intellectual Property I, L.P.Integrated proximity routing for content distribution
US8996653Oct 26, 2012Mar 31, 2015Google Inc.Systems and methods for client authentication
US8996664Aug 26, 2013Mar 31, 2015Amazon Technologies, Inc.Translation of resource identifiers using popularity information upon client request
US9003035Sep 28, 2010Apr 7, 2015Amazon Technologies, Inc.Point of presence management in request routing
US9003040Apr 29, 2013Apr 7, 2015Amazon Technologies, Inc.Request routing processing
US9009286May 6, 2013Apr 14, 2015Amazon Technologies, Inc.Locality based content distribution
US9009330Nov 4, 2010Apr 14, 2015Cloudflare, Inc.Internet-based proxy service to limit internet visitor connection speed
US9021112 *Mar 18, 2008Apr 28, 2015Level 3 Communications, LlcContent request routing and load balancing for content distribution networks
US9021127Mar 14, 2013Apr 28, 2015Amazon Technologies, Inc.Updating routing information based on client location
US9021128May 17, 2013Apr 28, 2015Amazon Technologies, Inc.Request routing using network computing components
US9021129Jun 3, 2013Apr 28, 2015Amazon Technologies, Inc.Request routing utilizing client location information
US9026616May 17, 2013May 5, 2015Amazon Technologies, Inc.Content delivery reconciliation
US9049247Nov 4, 2010Jun 2, 2015Cloudfare, Inc.Internet-based proxy service for responding to server offline errors
US9049268May 5, 2006Jun 2, 2015Microsoft Technology Licensing, LlcGlobal provisioning of millions of users with deployment units
US9083675Jun 4, 2013Jul 14, 2015Amazon Technologies, Inc.Translation of resource identifiers using popularity information upon client request
US9083743Jun 20, 2012Jul 14, 2015Amazon Technologies, Inc.Managing request routing information utilizing performance information
US9100462Oct 15, 2013Aug 4, 2015At&T Intellectual Property I, L.P.Anycast transport protocol for content distribution networks
US9106701Nov 4, 2013Aug 11, 2015Amazon Technologies, Inc.Request routing management based on network components
US9124603Aug 27, 2007Sep 1, 2015At&T Intellectual Property I., L.P.Methods and apparatus to select a peered voice over internet protocol (VoIP) border element
US9130756Mar 11, 2013Sep 8, 2015Amazon Technologies, Inc.Managing secure content in a content delivery network
US9135048Sep 20, 2012Sep 15, 2015Amazon Technologies, Inc.Automated profiling of resource usage
US9137302 *Dec 29, 2009Sep 15, 2015The Directv Group, Inc.Content distribution network selector
US9148486Nov 22, 2011Sep 29, 2015Cisco Technology, Inc.Content distribution through blind-cache instantiation
US9154551Jun 11, 2012Oct 6, 2015Amazon Technologies, Inc.Processing DNS queries to identify pre-processing information
US9160703Dec 10, 2014Oct 13, 2015Amazon Technologies, Inc.Request routing management based on network components
US9167032Oct 7, 2014Oct 20, 2015At&T Intellectual Property I, L.P.Internet protocol version 6 content routing
US9167036Feb 14, 2002Oct 20, 2015Level 3 Communications, LlcManaged object replication and delivery
US9172674Jun 20, 2012Oct 27, 2015Amazon Technologies, Inc.Managing request routing information utilizing performance information
US9176894Jul 14, 2014Nov 3, 2015Amazon Technologies, Inc.Managing resources using resource expiration data
US9185012Nov 21, 2014Nov 10, 2015Amazon Technologies, Inc.Latency measurement in resource requests
US9191292Oct 15, 2013Nov 17, 2015At&T Intellectual Property I, L.P.Integrated adaptive anycast for content distribution
US9191338Aug 25, 2014Nov 17, 2015Amazon Technologies, Inc.Request routing in a networked environment
US9191458Jun 5, 2014Nov 17, 2015Amazon Technologies, Inc.Request routing using a popularity identifier at a DNS nameserver
US9203921 *Aug 7, 2009Dec 1, 2015British Telecommunications Public Limited CompanyOperation of a content distribution network
US9208097Nov 12, 2013Dec 8, 2015Amazon Technologies, Inc.Cache optimization
US9210235Aug 28, 2013Dec 8, 2015Amazon Technologies, Inc.Client side cache management
US9237114Mar 14, 2013Jan 12, 2016Amazon Technologies, Inc.Managing resources in resource cache components
US9246776Mar 10, 2015Jan 26, 2016Amazon Technologies, Inc.Forward-based resource delivery network management techniques
US9246824Jul 25, 2013Jan 26, 2016At&T Intellectual Property I, L.P.Systems and methods to select peered border elements for an IP multimedia session based on quality-of-service
US9251112Aug 26, 2013Feb 2, 2016Amazon Technologies, Inc.Managing content delivery network service providers
US9253065Nov 21, 2014Feb 2, 2016Amazon Technologies, Inc.Latency measurement in resource requests
US9258268Aug 27, 2007Feb 9, 2016At&T Intellectual Property, I., L.P.Methods and apparatus to dynamically select a peered voice over internet protocol (VoIP) border element
US9294391Jun 4, 2013Mar 22, 2016Amazon Technologies, Inc.Managing network computing components utilizing request routing
US9298636 *Sep 29, 2011Mar 29, 2016Emc CorporationManaging data storage
US9323577Sep 20, 2012Apr 26, 2016Amazon Technologies, Inc.Automated profiling of resource usage
US9332078Mar 5, 2015May 3, 2016Amazon Technologies, Inc.Locality based content distribution
US9342620Oct 9, 2012May 17, 2016Cloudflare, Inc.Loading of web resources
US9369437 *Nov 4, 2010Jun 14, 2016Cloudflare, Inc.Internet-based proxy service to modify internet responses
US9385932 *Jan 26, 2015Jul 5, 2016Marlow Technologies, LlcUnified web hosting and content distribution
US9391949Dec 3, 2010Jul 12, 2016Amazon Technologies, Inc.Request routing processing
US20020126135 *May 7, 2002Sep 12, 2002Keith BallImage sharing for instant messaging
US20020161835 *Mar 26, 2002Oct 31, 2002Keith BallMeta content distribution network
US20040111491 *Dec 9, 2002Jun 10, 2004Sun Microsystems, Inc. A Delaware CorporationReducing overhead in reverse proxy servers when processing web pages
US20050036501 *Aug 10, 2004Feb 17, 2005Samsung Electronics Co., Ltd.Domain name service system and method thereof
US20050076104 *Jun 23, 2003Apr 7, 2005Barbara LiskovMethods and apparatus for performing content distribution in a content distribution network
US20050198269 *Feb 13, 2004Sep 8, 2005Champagne Andrew F.Method and system for monitoring border gateway protocol (BGP) data in a distributed computer network
US20060031506 *Apr 30, 2004Feb 9, 2006Sun Microsystems, Inc.System and method for evaluating policies for network load balancing
US20060164995 *Mar 14, 2005Jul 27, 2006Martin DjernaesMethod and apparatus for context-based prefix updates in border gateway protocol
US20060206610 *Mar 9, 2005Sep 14, 2006Yibei LingMethod, system and apparatus for location-aware content push service and location-based dynamic attachment
US20060277278 *Jun 6, 2005Dec 7, 2006International Business Machines CorporationDistributing workload among DNS servers
US20060277303 *Jun 6, 2005Dec 7, 2006Nikhil HegdeMethod to improve response time when clients use network services
US20070174463 *Mar 8, 2007Jul 26, 2007Level 3 Communications, LlcManaged object replication and delivery
US20070276900 *May 5, 2006Nov 29, 2007Microsoft CorporationGlobal provisioning of millions of users with deployment units
US20080040306 *Aug 2, 2006Feb 14, 2008Cisco Technology, Inc. (A California Corporation)Techniques for remapping content requests
US20080201331 *Feb 15, 2007Aug 21, 2008Bjorn Marius Aamodt EriksenSystems and Methods for Cache Optimization
US20080208967 *Mar 3, 2008Aug 28, 2008Hilliard William JMethod and System for Improved Internet Color
US20080235400 *Mar 18, 2008Sep 25, 2008Level 3 Communications, LlcContent request routing and load balancing for content distribution networks
US20080253382 *Jan 8, 2006Oct 16, 2008Matsushita Electric Industrial Co., Ltd.Multiple Interface Mobile Node With Simultaneous Home- And Foreign Network Connection
US20090037393 *Oct 14, 2008Feb 5, 2009Eric Russell FredricksenSystem and Method of Accessing a Document Efficiently Through Multi-Tier Web Caching
US20090052434 *Aug 21, 2007Feb 26, 2009James JacksonMethods and apparatus to select a voice over internet protocol (voip) border element
US20090059894 *Aug 27, 2007Mar 5, 2009James JacksonMethods and apparatus to select a peered voice over internet protocol (voip) border element
US20090059895 *Aug 27, 2007Mar 5, 2009Mehrad YasrebiMethods and apparatus to dynamically select a peered voice over internet protocol (voip) border element
US20090113057 *Oct 26, 2007Apr 30, 2009Jacobus Van Der MerweProximity Routing For Session Based Applications Using Anycast
US20090164614 *Dec 20, 2007Jun 25, 2009Christian Michael FDns wildcard beaconing to determine client location and resolver load for global traffic load balancing
US20090164646 *Dec 21, 2007Jun 25, 2009Christian Michael FMethod for determining network proximity for global traffic load balancing using passive tcp performance instrumentation
US20090245114 *Apr 1, 2008Oct 1, 2009Jayanth VijayaraghavanMethods for collecting and analyzing network performance data
US20090248697 *Mar 31, 2008Oct 1, 2009Richardson David RCache optimization
US20100057894 *Aug 27, 2008Mar 4, 2010At&T Corp.Targeted Caching to Reduce Bandwidth Consumption
US20100088405 *Oct 8, 2008Apr 8, 2010Microsoft CorporationDetermining Network Delay and CDN Deployment
US20100121945 *Nov 11, 2008May 13, 2010At&T Corp.Hybrid Unicast/Anycast Content Distribution Network System
US20110029596 *Oct 16, 2009Feb 3, 2011At&T Intellectual Property I, L.P.Anycast Transport Protocol for Content Distribution Networks
US20110040861 *Feb 17, 2011At&T Intellectual Property I, L.P.Integrated Proximity Routing for Content Distribution
US20110082916 *Apr 7, 2011Limelight Networks, Inc.Enhanced Anycast For Edge Server Selection
US20110082944 *Apr 26, 2010Apr 7, 2011Limelight Networks, Inc.Real-Time Message Queuing For A Processing Ring
US20110145405 *Jun 16, 2011Jayanth VijayaraghavanMethods for Collecting and Analyzing Network Performance Data
US20110145437 *Aug 7, 2009Jun 16, 2011Benjamin Paul Niven-JenkinsOperation of a content distribution network
US20110153719 *Jun 23, 2011At&T Intellectual Property I, L.P.Integrated Adaptive Anycast for Content Distribution
US20110153941 *Jun 23, 2011At&T Intellectual Property I, L.P.Multi-Autonomous System Anycast Content Delivery Network
US20110161461 *Aug 7, 2009Jun 30, 2011Niven-Jenkins Benjamin PContent distribution network
US20110173248 *Jul 14, 2011Alcatel-Lucent Usa Inc.Method for providing on-path content distribution
US20110231475 *Mar 22, 2010Sep 22, 2011At&T Intellectual Property I, L.P.Internet Protocol Version 6 Content Routing
US20120022942 *Jan 26, 2012Lee Hahn HollowayInternet-based proxy service to modify internet responses
US20120116896 *May 10, 2012Lee Hahn HollowayInternet-based proxy service to modify internet responses
US20120124191 *Jan 24, 2012May 17, 2012BitGravity, Inc.Managing tcp anycast requests
US20120131192 *Nov 22, 2010May 24, 2012Maccarthaigh ColmRequest routing processing
US20120198045 *Apr 11, 2012Aug 2, 2012Edgecast Networks, Inc.Global load balancing on a content delivery network
US20120246306 *Sep 27, 2012At&T Intellectual Property Ii, L.P.Unified Web Hosting and Content Distribution System and Method for Assuring Predetermined Performance Levels
US20130064135 *Mar 14, 2013Fujitsu LimitedDistribution system, distribution method, and memory medium thereof
US20130227060 *Feb 14, 2013Aug 29, 2013Research In Motion LimitedMobile media content delivery
US20140108674 *Oct 7, 2013Apr 17, 2014Limelight Networks, Inc.Anycast redirect to unicast content download
US20150146722 *Nov 22, 2013May 28, 2015Cisco Technology, Inc.Optimized content routing distribution using proximity based on predictive client flow trajectories
US20150200831 *Jan 26, 2015Jul 16, 2015Marlow Technologies, LlcUnified web hosting and content distribution
EP1885088A1 *Aug 4, 2006Feb 6, 2008Alcatel LucentRouting device, routing module and routing method for an access network
WO2008015268A1 *Aug 3, 2007Feb 7, 2008Alcatel LucentRouting device, routing module and routing method for an access network
WO2009086373A3 *Dec 23, 2008Sep 11, 2009Yahoo! Inc.Mapless global traffic load balancing via anycast
WO2013078383A1 *Nov 21, 2012May 30, 2013Cisco Technology, Inc.Content distribution through blind-cache instantiation
Classifications
U.S. Classification709/229, 709/217
International ClassificationH04L29/08, H04L29/06, H04L29/12
Cooperative ClassificationH04L29/12207, H04L29/06, H04L29/12066, H04L61/1511, H04L61/20, H04L67/2895, H04L67/2842, H04L67/288
European ClassificationH04L61/15A1, H04L29/12A2A1, H04L29/06, H04L29/08N27X9, H04L29/08N27S, H04L29/08N27X4
Legal Events
DateCodeEventDescription
Jun 4, 2002ASAssignment
Owner name: GENUITY INC., MASSACHUSETTS
Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:SLOCOMBE, MICHAEL;FULLER, VINCENT A.;MILLER, MATTHEW;ANDOTHERS;REEL/FRAME:012951/0535;SIGNING DATES FROM 20020108 TO 20020515
Jul 29, 2003ASAssignment
Owner name: LEVEL 3 COMMUNICATIONS, LLC, COLORADO
Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:GENUITY, INC.;REEL/FRAME:014324/0285
Effective date: 20030204
May 21, 2004ASAssignment
Owner name: LEVEL 3 COMMUNICATIONS, INC., COLORADO
Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:LEVEL 3 COMMUNICATIONS, LLC;REEL/FRAME:014653/0859
Effective date: 20040520
Sep 6, 2006ASAssignment
Owner name: MERRILL LYNCH CAPITAL CORPORATION, AS COLLATERAL A
Free format text: SECURITY AGREEMENT;ASSIGNORS:LEVEL 3 COMMUNICATIONS, INC.;ICG COMMUNICATIONS, INC.;REEL/FRAME:018207/0120
Effective date: 20060627
Mar 12, 2007ASAssignment
Owner name: LEVEL 3 COMMUNICATIONS, LLC, COLORADO
Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:LEVEL 3 COMMUNICATIONS, INC.;REEL/FRAME:018989/0678
Effective date: 20070312
Owner name: LEVEL 3 COMMUNICATIONS, LLC,COLORADO
Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:LEVEL 3 COMMUNICATIONS, INC.;REEL/FRAME:018989/0678
Effective date: 20070312