Replica routing
First Claim
Patent Images
1. An internetwork replica routing system comprising:
- a plurality of server replicas, at least one replica router, and at least one client computer interconnected by a communications internetwork;
the client computer being programmed to cause a network request, including a source interwork address of the network request, to be transmitted over the communications internetwork;
at least one replica router being programmed to receive the network request and the source internetwork address of the network request and to calculate a performance metric value for each of at least some of the server replicas that specifies estimated communication performance between the client computer and the server replica, based upon the client computer'"'"'s location in the internetwork as evidenced by the source internetwork address of the network request, and based upon a replica routing database that contains performance metric information with respect to a plurality of IP address portions sufficient to make routing decisions based upon the network request, and being programmed to cause the client computer to be directed to at least one server replica that is estimated to provide good performance based upon the client computer'"'"'s location in the internetwork, the replica router selecting the at least one server replica to which it causes the client computer to be directed based on the performance metric values of the server replicas as calculated by the replica router, the replica router further being programmed to update dynamically the replica routing database based on internetwork performance information periodically received by the replica router in the form of advertisements, wherein the period of updates may dynamically change;
the server replica to which the client computer is directed being programmed to respond to the network request from the client computer.
5 Assignments
0 Petitions
Accused Products
Abstract
The present invention is a new method called replica routing that automatically directs client computers that request a service to a server replica for that service. The replica chosen by replica routing is the replica that is expected to provide the best performance to the client based upon the client'"'"'s location in the internetwork topology and the estimated performance of the internetwork. In addition, the system and method is designed to permit new replicas to be flexibly added undue administrative overhead.
-
Citations
37 Claims
-
1. An internetwork replica routing system comprising:
-
a plurality of server replicas, at least one replica router, and at least one client computer interconnected by a communications internetwork; the client computer being programmed to cause a network request, including a source interwork address of the network request, to be transmitted over the communications internetwork; at least one replica router being programmed to receive the network request and the source internetwork address of the network request and to calculate a performance metric value for each of at least some of the server replicas that specifies estimated communication performance between the client computer and the server replica, based upon the client computer'"'"'s location in the internetwork as evidenced by the source internetwork address of the network request, and based upon a replica routing database that contains performance metric information with respect to a plurality of IP address portions sufficient to make routing decisions based upon the network request, and being programmed to cause the client computer to be directed to at least one server replica that is estimated to provide good performance based upon the client computer'"'"'s location in the internetwork, the replica router selecting the at least one server replica to which it causes the client computer to be directed based on the performance metric values of the server replicas as calculated by the replica router, the replica router further being programmed to update dynamically the replica routing database based on internetwork performance information periodically received by the replica router in the form of advertisements, wherein the period of updates may dynamically change; the server replica to which the client computer is directed being programmed to respond to the network request from the client computer. - View Dependent Claims (2, 4, 5, 6, 7, 8, 21)
-
-
3. An internetwork replica routing system comprising:
-
a plurality of server replicas, at least one replica router, and at least one client computer interconnected by a communications internetwork; the client computer being programmed to cause a network request, including a source internetwork address of the network request, to be transmitted over the communications internetwork; at least one replica router being programmed to receive the network request and the source internetwork address of the network request and to calculate a performance metric value for each of at least some of the server replicas that specifies estimated communication performance between the client computer and the server replica, based upon the client computer'"'"'s location in the internetwork as evidenced by the source internetwork address of the network request, and based upon a replica routing database, and being programmed to cause the client computer to be directed to at least one server replica that is estimated to provide good performance based upon the client computer'"'"'s location in the internetwork, the replica router selecting the at least one server replica to which it causes the client computer to be directed based on the performance metric values of the server replicas as calculated by the replica router, the replica router further being programmed to update dynamically the replica routing database based on internetwork performance information periodically received by the replica router, wherein the period of updates may dynamically change, the server replica to which the client computer is directed being programmed to respond to a network request from the client computer;
the server replicas being programmed to cause server replica advertisements to be sent to the replica router, the advertisements containing internetwork performance information from which the replica router can calculate the performance metric value;
the replica router being programmed to maintain a database computed from the server replica advertisements;wherein each of the replica advertisements contains the actual source IP address of the server replica that caused it to be sent, and at least one replica router is programmed to match source IP addresses accompanying the replica advertisements to the actual source IP address contained in the replica advertisements to determine whether any of the server replicas are located behind firewalls, and to select a server replica or another replica router to which it causes the client computer to be directed based on whether the client computer is located behind a common firewall with the server replica or another replica router.
-
-
9. An internetwork replica routing system comprising:
-
a plurality of server replicas, a plurality of replica routers arranged in a hierarchy, and at least one client computer interconnected by a communications internetwork; the client computer being programmed to cause a network request, including a source internetwork address of the network request, to be transmitted over the communications internetwork; at least one of the replica routers being programmed to receive the network request and the source internetwork address of the network request and to calculate a performance metric value for each of at least some of the server replicas that specifies estimated communication performance between the client computer and the server replica, based upon the client computer'"'"'s location in the internetwork as evidenced by the source internetwork address of the network request, and based upon a replica routing database, and being programmed to cause the client computer to be directed to at least one server replica that is estimated to provide good performance based upon the client computer'"'"'s location in the internetwork, the replica router selecting the at least one server replica to which it causes the client computer to be directed based on the performance metric values of the server replicas as calculated by the replica router, the replica router further being programmed to update dynamically the replica routing database based on internetwork performance information periodically received by the replica router, wherein the period of updates may dynamically change, the server replica to which the client computer is directed being programmed to respond to a network request from the client computer; at least one of the replica routers being programmed to cause the client computer to be directed to a server replica that is estimated to provide good performance based upon the client computer'"'"'s location in the internetwork by directing the client computer to a replica router lower in the hierarchy; at least one the replica routers being programmed to cause a replica router advertisement to be sent to a replica router higher in the hierarchy, the replica router advertisement containing information from which the replica router higher in the hierarchy can cause the performance metric value to be calculated; and the replica router higher in the hierarchy being programmed to store the replica router advertisement in a database of advertisements; wherein the replica router higher in the hierarchy is programmed to match the replica router advertisement to its actual source IP address to determine whether the replica router that caused the replica router advertisement to be sent is located behind a firewall. - View Dependent Claims (29)
-
-
10. A method of replica routing in a communications internetwork comprising a plurality of server replicas, at least one replica router, and at least one client computer, comprising the steps of:
-
at the client computer, causing a network request, including a source internetwork address of the network request, to be transmitted over the communications internetwork; receiving the network request, and the source internetwork address of the network request, at at least one replica router; calculating, at the replica router, a performance metric value for each of at least some of the server replicas that specifies estimated communication performance between the client computer and the server replica, based upon the client computer'"'"'s location in the internetwork as evidenced by the source internetwork address of the network request, and based upon a replica routing database that contains performance metric information with respect to a plurality of IP address portions sufficient to make routing decisions based upon the network request; causing the client computer to be directed to at least one server replica that is estimated to provide good performance based upon the client computer'"'"'s location in the internetwork, the at least one server replica to which the client computer is directed being selected based on the performance metric values of the server replicas as calculated by the replica router; updating dynamically, at the replica router, the replica routing database based on internetwork performance information periodically received by the replica router in the form of advertisements, wherein the period of updates may dynamically change; and responding, at the server replica to which the client computer is directed, to the network request from the client computer. - View Dependent Claims (11, 13, 14, 15, 16, 17, 22)
-
-
12. A method of replica routing in a communications internetwork comprising a plurality of server replicas, at least one replica router, and at least one client computer, comprising the steps of:
-
at the client computer, causing a network request, including a source internetwork address of the network request, to be transmitted over the communications internetwork; receiving the network request, and the source internetwork address of the network request, at least one replica router; calculating, at the replica router, a performance metric value for each of at least some of the server replicas that specifies estimated communication performance between the client computer and the server replica, based upon the client computer'"'"'s location in the internetwork as evidenced by the source internetwork address of the network request, and based upon a replica routing database; causing the client computer to be directed to at least one server replica that is estimated to provide good performance based upon the client computer'"'"'s location in the internetwork, the at least one server replica to which the client computer is directed being selected based on the performance metric values of the server replicas as calculated by the replica router; updating dynamically, at the replica router, the replica routing database based on internetwork performance information periodically received by the replica router, wherein the period of updates may dynamically change; responding, at the server replica to which the client computer is directed, to the network request from the client computer; at the server replicas, causing server replica advertisements to be sent to the replica router, the advertisements containing internetwork performance information from which the replica router can calculate the performance metric values; and the replica router maintaining a database computed from the server replica advertisements; wherein each of the replica advertisements contains the actual source IP address of the server replica that caused it to be sent, and further comprising the step of matching, at the replica router, source IP addresses accompanying the replica advertisements to the actual source IP address contained in the replica advertisements to determine whether any of the server replicas are located behind firewalls, and to select a server replica or another replica router to which it causes the client computer to be directed based on whether the client computer is located behind a common firewall with the server replica or another replica router.
-
-
18. A method of replica routing in a communications internetwork comprising a plurality of server replicas, a plurality of replica routers arranged in a hierarchy, and at least one client computer, comprising the steps of:
-
at the client computer, causing a network request, including a source internetwork address of the network request, to be transmitted over the communications internetwork; receiving the network request, and the source internetwork address of the network request, at at least one replica router; calculating, at the replica router, a performance metric value for each of at least some of the server replicas that specifies estimated communication performance between the client computer and the server replica, based upon the client computer'"'"'s location in the internetwork as evidenced by the source internetwork address of the network request, and based upon a replica routing database; the replica router causing the client computer to be directed to at least one server replica that is estimated to provide good performance based upon the client computer'"'"'s location in the internetwork by directing the client computer to a replica router lower in the hierarchy, the at least one server replica to which the client computer is directed being selected based on the performance metric values of the server replicas as calculated by the replica router; updating dynamically, at the replica router, the replica routing database based on internetwork performance information periodically received by the replica router, wherein the period of updates may be dynamically change; and responding, at the server replica to which the client computer is directed, to the network request from the client computer; causing a replica router advertisement to be sent from one of the replica routers to a replica router higher in the hierarchy, the replica router advertisement containing information from which the replica router higher in the hierarchy can cause the performance metric value to be calculated; the replica router higher in the hierarchy storing the replica router advertisement in a database of advertisements; and matching, at the replica router higher in the hierarchy, the replica router advertisement to its actual source IP address to determine whether the replica router that caused the replica router advertisement to be sent is located behind a firewall.
-
-
19. An internetwork replica routing system comprising:
-
a plurality of server replicas, at least one replica router, and at least one client computer interconnected by a communications internetwork; at least one replica router being programmed to receive server replica advertisements, each of the advertisements containing at least one identifier of a network in the communications internetwork to be serviced by a server replica and internetwork performance information with respect to the network; the client computer being programmed to cause a network request, including a source internetwork address of the network request, to be transmitted over the communications internetwork; at least one replica router being programmed to maintain a database computed from the server replica advertisements, to receive the network request including the source internetwork address of the network request, and to cause the client computer to be directed to at least one of the server replicas based upon the relationship between the networks identified in the advertisements in the database and a network in which the client computer is located as evidenced by the source internetwork address of the network request, the replica router further being programmed to update dynamically the database based on server replica advertisements periodically received by the replica router in the form of advertisements, wherein the period of updates may dynamically change, the database containing performance metric information with respect to a plurality of IP address portions sufficient to make routing decisions based upon the network request; the server replica to which the client computer is directed being programmed to respond to the network request from the client computer.
-
-
20. A method of replica routing in a communications internetwork comprising a plurality of server replicas, at least one replica router, and at least one client computer, comprising the steps of:
-
causing server replica advertisements to be sent to the replica router, each of the advertisements containing at least one identifier of a network in the communications internetwork to be serviced by a server replica and internetwork performance information with respect to the network; at the client computer, causing a network request, including a source internetwork address of the network request, to be transmitted over the communications internetwork; the replica router maintaining a database computed from the server replica advertisements; receiving, at the replica router, the network request including the source internetwork address of the network request; causing the client computer to be directed to at least one of the server replicas based upon the relationship between the networks identified in the advertisements in the database and a network in which the client computer is located as evidenced by the source internetwork address of the network request; updating dynamically, at the replica router, the database based on server replica advertisements periodically received by the replica router, wherein the period of updates may dynamically change, the database containing performance metric information with respect to a plurality of IP address portions sufficient to make routine decisions based upon the network request; and responding, at the server replica to which the client computer is directed, to a network request from the client computer.
-
-
23. An internetwork replica routing system comprising:
-
a plurality of server replicas, at least one replica router, and at least one client computer interconnected by a communications internetwork; the client computer being programmed to cause a network request, including a source internetwork address of the network request, to be transmitted over the communications internetwork; the replica router being programmed to receive the network request including the source internetwork address of the network request, and to calculate a performance metric value for each of at least some of the server replicas that specifies estimated communication performance between the client computer and the server replica based upon a replica routing database that contains performance metric information with respect to a plurality of IP address portions sufficient to make routing decisions based upon the network request, and to cause identification of a plurality of server replicas that are estimated to provide good performance to be sent to the client computer; the client computer being programmed to perform empirical performance experiments to choose one of the plurality of server replicas, estimated by the replica router to provide good performance, from which to access information; the server replica identified by the replica router and chosen by the client computer being programmed to respond to a network request from the client computer.
-
-
24. A method of replica routing in a communications internetwork comprising a plurality of server replicas, at least one replica router, and at least one client computer, comprising the steps of:
-
at the client computer, causing a network request, including a source internetwork address of the network request, to be transmitted over the communications internetwork; at the replica router, receiving the network request including the source internetwork address of the network request, and calculating a performance metric value for each of at least some of the server replicas that specifies estimated communication performance between the client computer and the server replica based upon a replica routing database that contains performance metric information with respect to a plurality of IP address portions sufficient to make routing decisions based upon the network request, and causing identification of a plurality of server replicas that are estimated to provide good performance to be sent to the client computer; at the client computer, performing empirical performance experiments to choose one of the plurality of server replicas, estimated by the replica router to provide good performance, from which to access information; at the server replica identified by the replica router and chosen by the client computer, responding to the network request from the client computer.
-
-
25. A computer program product comprising:
- a computer usable medium having computer readable program code tangibly embedded in said computer program product, the program code being configured to cause a replica router to;
receive a network request, including a source internetwork address of the network request, the network request including the source internetwork address of the network request being transmitted over a communications internetwork of an internetwork replica routing system interconnecting at least one replica router, at least one client computer that causes the network request including the source internetwork address of the network request to be transmitted, and a plurality of server replicas programmed to respond to the network request from the client computer; calculate a performance metric value for each of at least some of the server replicas that specifies estimated communication performance between the client computer and the server replica, based upon the client computer'"'"'s location in the internetwork as evidenced by the source internetwork address of the network request, based upon a replica routing database that contains performance metric information with respect to a plurality of IP address portions sufficient to make routing decisions based upon the network request; cause the client computer to be directed to at least one server replica that is estimated to provide good performance based upon the client computer'"'"'s location in the internetwork, the replica router selecting the at least one server replica to which it causes the client computer to be directed based on the performance metric values of the server replicas as calculated by the replica router; and update dynamically the replica routing database based on internetwork performance information periodically received by the replica router in the form of advertisements, wherein the period of updates may dynamically change.
- a computer usable medium having computer readable program code tangibly embedded in said computer program product, the program code being configured to cause a replica router to;
-
26. A computer program product comprising:
- a computer usable medium having computer readable program code tangibly embedded in said computer program product, the program code being configured to cause a replica router to;
receive a network request, including a source internetwork address of the network request, the network request including the source internetwork address of the network request being transmitted over a communications internetwork of an internetwork replica routing system interconnecting at least one replica router, at least one client computer that causes the network request including the source internetwork address of the network request to be transmitted, and a plurality of server replicas programmed to respond to a network request from the client computer; receive server replica advertisements, each of the advertisements containing at least one identifier of a network in the communications internetwork to be serviced by a server replica and internetwork performance information with respect to the network; maintain a database computed from the server replica advertisements; cause the client computer to be directed to at least one of the server replicas based upon the relationship between the networks identified in the advertisements in the database and a network in which the client computer is located as evidenced by the source internetwork address of the network request; and update dynamically the database based on server replica advertisements periodically received by the replica router, wherein the period of updates may dynamically change, the database containing performance metric information with respect to a plurality of IP address portions sufficient to make routing decisions based upon the network request.
- a computer usable medium having computer readable program code tangibly embedded in said computer program product, the program code being configured to cause a replica router to;
-
27. A computer program product comprising:
- a computer usable medium having computer readable program code tangibly embedded in said computer program product,
the program code being configured to cause a server replica to cause server replica advertisements to be sent to a replica router over a communications internetwork of an internetwork replica routing system interconnecting a plurality of server replicas, at least one client computer, and at least one replica router, each of the advertisements containing at least one identifier of a network in the communications internetwork to be serviced by the server replica and internetwork performance information with respect to the network; the client computer causing a network request for access to a server replica and a source internetwork address of the network request to be transmitted over the communications internetwork, and the replica router receiving the network request and the internetwork address; and the program code being configured to cause the server replica to respond to a network request, the network request including a source internetwork address of the network request being caused to be transmitted over the communications internetwork by the client computer and being received by the replica router, which maintains a database computed from the server replica advertisements, which causes the client computer to be directed to the server replica based upon the relationship between the networks identified in the advertisements in the database and a network in which the client computer is located as evidenced by the source internetwork address of the network request, and which updates dynamically the database based on server replica advertisements periodically received by the replica router, wherein the period of updates may dynamically change, the database containing performance metric information with respect to a plurality of IP address portions sufficient to make routing decisions based upon the network request.
- a computer usable medium having computer readable program code tangibly embedded in said computer program product,
-
28. A computer program product comprising:
- a computer usable medium having computer readable program code tangibly embedded in said computer program product, the program code being configured to cause a client computer to;
cause a network request, including a source internetwork address of the network request, to be transmitted over a communications internetwork of an internetwork replica routing system interconnecting at least one client computer, a plurality of server replicas programmed to respond to a network request from the client computer, and at least one replica router that calculates a performance metric value for each of at least some of the server replicas that specifies estimated communication performance between the client computer and the server replica based upon a replica routing database that contains performance metric information with respect to a plurality of IP address portion sufficient to make routing decisions based upon the network request transmitted over the communications request, and that causes identification of a plurality of server replicas that are estimated to provide good performance to be sent to the client computer; and perform empirical performance experiments to choose one of the plurality of server replicas from which to access information and to cause the information to be accessed from the server replica identified by the replica router and chosen by the client computer.
- a computer usable medium having computer readable program code tangibly embedded in said computer program product, the program code being configured to cause a client computer to;
-
30. An internetwork replica routing system comprising:
-
a plurality of server replicas, at least one replica router, and at least one client computer interconnected by a communications internetwork; the client computer being programmed to cause a network request, including a source internetwork address of the network request, to be transmitted over the communications internetwork; at least one replica router being programmed to receive the network request including the source internetwork address of the network request and to select a server replica having a performance metric value better than at least some of the server replicas, the performance metric value being an estimate of communication performance between the client computer and the server replica, the replica router selecting the server replica based upon the client computer'"'"'s location in the internetwork as evidenced by the source internetwork address of the network request, and based upon a replica routing database that contains a plurality of IP address portions sufficient to make routing decisions based upon the network request, the replica routing database being computed using performance metric information with respect to a plurality of IP address portions sufficient to make routing decisions based upon the network request, the replica router being programmed to cause the client computer to be directed to at least one server replica that is estimated to provide good performance based upon the client computer'"'"'s location in the internetwork, the replica router further being programmed to update dynamically the replica routing database based on advertisements periodically received by the replica router, wherein the period of updates may dynamically change, the advertisements being computed based on internetwork performance information; the server replica to which the client computer is directed being programmed to respond to the network request from the client computer. - View Dependent Claims (32, 33)
-
-
31. An internetwork replica routing system comprising:
-
a plurality of server replicas, at least one replica router, and at least one client computer interconnected by a communications internetwork; at least one replica router being programmed to receive server replica advertisements, each of the advertisements containing at least one identifier of a network in the communications internetwork to be serviced by a server replica, the advertisements being computed using internetwork performance information with respect to the network; the client computer being programmed to cause a network request, including a source internetwork address of the network request, to be transmitted over the communications internetwork; at least one replica router being programmed to maintain a database computed from the server replica advertisements, to receive the network request including the source internetwork address of the network request, and to cause the client computer to be directed to at least one of the server replicas based upon the relationship between the networks identified in the advertisements in the database and a network in which the client computer is located as evidenced by the source internetwork address of the network request, the replica router further being programmed to update dynamically the database based on server replica advertisements periodically received by the replica router, wherein the period of updates may dynamically change, the database containing a plurality of IP address portions sufficient to make routing decisions based upon the network request, the database being computed using performance metric information with respect to a plurality of IP address portions sufficient to make routing decisions based upon the network request; the server replica to which the client computer is directed being programmed to respond to the network request from the client computer.
-
-
34. An internetwork replica routing system comprising:
-
a plurality of server replicas, a plurality of replica routers, and at least one client computer interconnected by a communications internetwork; the client computer being programmed to cause a first network request, including a first internetwork source address, to be transmitted over the communications internetwork; a first replica router being programmed to receive the first network request including the first internetwork source address and to select a second replica router, and being programmed to cause a second network request including a second internetwork source address to be sent to the second replica router; the second replica router selecting at least one server replica that is estimated to provide good performance based upon the client computer'"'"'s location in the internetwork as evidenced by the second internetwork source address, the second replica router selecting the at least one server replica to which it causes the client computer to be directed based upon a replica routing database, the replica routing database being computer using performance metric information with respect to a plurality of IP address portions sufficient to make routing decisions based upon the second network request, the second replica router further being programmed to update dynamically the replica routing database based on internetwork performance information periodically received by the second replica router, wherein the period of updates may dynamically change, the at least one server replica to which the client computer is directed being programmed to respond to a network request from the client computer. - View Dependent Claims (35, 36, 37)
-
Specification