System and method for partitioning address space in a proxy cache server cluster
First Claim
1. A proxy partition cache architecture for vending objects to requesting clients comprising:
- a plurality of proxy cache servers for caching and vending objects from a storage location to a requesting client through an interconnected load-balancing mechanism adapted to selectively provide client requests to each of the plurality of proxy cache servers based upon load-balancing considerations;
a network segment interconnecting each of the proxy cache servers so as to enable data to pass between the proxy cache servers; and
a mechanism in each server of the plurality of proxy cache servers adapted to (a) receive a request for an object from the load-balancing mechanism, (b) identify a discrete server of the plurality of proxy cache servers that is designated to contain the object, based upon an address of the object, if a size of the object exceeds a cutoff value (c) referring the request to the discrete server if the size of the object exceeded the cutoff value and (d) return the object from the discrete server to the server receiving the request from the load-balancing mechanism for vending to the client unless the size of the object is below the cutoff value in which case the object is available or otherwise acquired directly from the server receiving the request and vended to the client.
16 Assignments
0 Petitions
Accused Products
Abstract
A proxy partition cache (PPC) architecture and a technique for address-partitioning a proxy cache consisting of a grouping of discrete, cooperating caches (servers) is provided. Client requests for objects (files) of a given size are redirected or reassigned to a single cache in the grouping, notwithstanding the cache to which the request is made by the load-balancing mechanism (such as a Layer 4 switch) based upon load-balancing considerations. The file is then returned to the switch via the switch-designated cache for vending to the requesting client. The redirection/reassignment occurs according to a function within the cache to which the request is directed so that the switch remains freed from additional tasks that can compromise speed.
-
Citations
19 Claims
-
1. A proxy partition cache architecture for vending objects to requesting clients comprising:
-
a plurality of proxy cache servers for caching and vending objects from a storage location to a requesting client through an interconnected load-balancing mechanism adapted to selectively provide client requests to each of the plurality of proxy cache servers based upon load-balancing considerations;
a network segment interconnecting each of the proxy cache servers so as to enable data to pass between the proxy cache servers; and
a mechanism in each server of the plurality of proxy cache servers adapted to (a) receive a request for an object from the load-balancing mechanism, (b) identify a discrete server of the plurality of proxy cache servers that is designated to contain the object, based upon an address of the object, if a size of the object exceeds a cutoff value (c) referring the request to the discrete server if the size of the object exceeded the cutoff value and (d) return the object from the discrete server to the server receiving the request from the load-balancing mechanism for vending to the client unless the size of the object is below the cutoff value in which case the object is available or otherwise acquired directly from the server receiving the request and vended to the client. - View Dependent Claims (2, 3, 4, 5, 6, 7)
-
-
8. A method for address-partitioning a proxy cache defined by a group of proxy cache servers for vending objects to requesting clients comprising:
-
caching and vending objects from a plurality of proxy cache servers to a requesting client through an interconnected load-balancing mechanism, including selectively providing client requests to each of the plurality of proxy cache servers based upon load-balancing considerations;
interconnecting each of the proxy cache servers through a network segment so as to enable data to pass between the proxy cache servers;
in each server of the plurality of proxy cache servers, (a) receiving a request for an object from the load-balancing mechanism, (b) identifying a discrete server of the plurality of proxy cache servers that is designated to contain the object, based upon an address of the object, (c) referring the request to the discrete server over the network segment and (d) returning the object from the discrete server to the server receiving the request from the load-balancing mechanism for vending to the client; and
skipping (b)-(d) if a size of the object is below a cutoff value and directly vending the object to the client from the server which initially received the request for the object. - View Dependent Claims (9, 10, 11, 12, 13, 14)
-
-
15. A computer-readable medium including program instructions for address-partitioning a proxy cache defined by a group of proxy cache servers for vending objects to requesting clients, the computer-readable medium including instructions for performing the steps of:
-
caching and vending objects from a plurality of proxy cache servers to a requesting client through an interconnected load-balancing mechanism, including selectively providing client requests to each of the plurality of proxy cache servers based upon load-balancing considerations;
interconnecting each of the proxy cache servers through a network segment so as to enable data to pass between the proxy cache servers;
in each server of the plurality of proxy cache servers, (a) receiving a request for an object from the load-balancing mechanism, (b) identifying a discrete server of the plurality of proxy cache servers that is designated to contain the object, based upon an address of the object, (c) referring the request to the discrete server over the network segment and (d) returning the object from the discrete server to the server receiving the request from the load-balancing mechanism for vending to the client; and
skipping (b)-(d) if a size of the object is below a cutoff value and directly vending the object to the client from the server which received the request.
-
-
16. A proxy partition cache architecture for vending objects to requesting clients comprising:
-
a plurality of proxy cache servers for caching and vending objects from a storage location to a requesting client through an interconnected load-balancing mechanism adapted to selectively provide client requests to each of the plurality of proxy cache servers based upon load-balancing considerations;
a network segment interconnecting each of the proxy cache servers so as to enable data to pass between the proxy cache servers; and
a mechanism in each server of the plurality of proxy cache servers adapted to (a) receive a request for an object from the load-balancing mechanism, (b) identify a discrete server of the plurality of proxy cache servers that is designated to contain the object, based upon an address of the object, (c) referring the request to the discrete server and (d) return the object from the discrete server to the server receiving the request from the load-balancing mechanism for vending to the client, wherein the mechanism includes means for enabling a redirection of the client request to the discrete server from the server receiving the request from the load-balancing mechanism and the mechanism further includes means for notifying the discrete server to receive the referred request so that a client redirection is expected, and allowing the discrete server to reject the request when the request is not recognized as a referred request by the mechanism.
-
-
17. A proxy partition cache architecture for vending objects to requesting clients comprising:
-
a plurality of proxy cache servers for caching and vending objects from a storage location to a requesting client through an interconnected load-balancing mechanism adapted to selectively provide client requests to each of the plurality of proxy cache servers based upon load-balancing considerations;
a network segment interconnecting each of the proxy cache servers so as to enable data to pass between the proxy cache servers; and
a mechanism in each server of the plurality of proxy cache servers adapted to (a) receive a request for an object from the load-balancing mechanism, (b) identify a discrete server of the plurality of proxy cache servers that is designated to contain the object, based upon an address of the object, (c) referring the request to the discrete server and (d) return the object from the discrete server to the server receiving the request from the load-balancing mechanism for vending to the client, wherein the mechanism includes means for allowing vending of a file from a server other than the one selected by the modulo mechanism based upon a directory entry that indicates a current sever location and data freshness of the file.
-
-
18. A method for address-partitioning a proxy cache defined by a group of proxy cache servers for vending objects to requesting clients comprising:
-
caching and vending objects from a plurality of proxy cache servers to a requesting client through an interconnected load-balancing mechanism, including selectively providing client requests to each of the plurality of proxy cache servers based upon load-balancing considerations;
interconnecting each of the proxy cache servers through a network segment so as to enable data to pass between the proxy cache servers; and
in each server of the plurality of proxy cache servers, (a) receiving a request for an object from the load-balancing mechanism, (b) identifying a discrete server of the plurality of proxy cache servers that is designated to contain the object, based upon an address of the object, (c) referring the request to the discrete server over the network segment and (d) returning the object from the discrete server to the server receiving the request from the load-balancing mechanism for vending to the client;
wherein the steps of referring and returning include redirecting of the client request to the discrete server from the server receiving the request from the load-balancing mechanism. - View Dependent Claims (19)
-
Specification