The invention is a method and apparatus for facilitating load balancing in a server farm. In accordance with the invention, all of the information about each server necessary for a load balancing program to define and execute a load balancing algorithm is stored at a predetermined URL or each server. The load balancer can query the predefined URL, which returns the necessary information. The load balancer then dynamically configures the load balancing algorithm in accordance with the returned information.
|
1. A method of configuring a load balancer for dispatching client requests in a server farm comprising:
initializing a load balancer by identifying to said load balancer, address information for a plurality of servers in a server farm;
individually polling each of the plurality of servers by the load balancer so as to obtain a configuration file from each polled server if available, wherein:
each obtained configuration file contains the parameters necessary to configure the load balancer for bringing the associated polled server on-line; and
polling is implemented by repeating for each of said plurality of servers:
selecting by said load balancer, a next one of said plurality of servers;
sending a request across a corresponding network from said load balancer to said next one of said plurality of servers for a corresponding configuration file by specifying a predefined uniform resource locator (URL) using a standard network protocol request, wherein the corresponding configuration file is stored in a local memory of said next one of said plurality of servers identified by the predefined uniform resource locator (URL) and contains parameters including variables to be applied for configuring a load balancing scheme implemented by said load balancer;
waiting for a reply from said next one of said plurality of servers;
receiving either said corresponding configuration file formatted into a markup language supported by the load balancer or an error message from said next one of said plurality of servers; and
validating parameters in said corresponding configuration file if received; and
configuring a load balancing algorithm by said load balancer in accordance with said parameters that were read out of each corresponding configuration file.
16. A computing apparatus for performing load balancing of client requests in a server farm comprising:
means for initializing a load balancer by identifying to said load balancer, address information for a plurality of servers in a server farm;
means for interfacing to a network to receive client requests directed to one of said plurality of servers via said network;
means for individually polling each of the plurality of servers by the load balancer so as to obtain a configuration file from each polled server if available, wherein:
each obtained configuration file contains the parameters necessary to configure the load balancer for bringing the associated polled server on-line; and
polling is implemented by repeating for each of said plurality of servers:
means for selecting by said load balancer, a next one of said plurality of servers;
means for sending a request across a corresponding network from said load balancer to said next one of said plurality of servers for a corresponding configuration file by specifying a predefined uniform resource locator (URL) using a standard network protocol request, wherein the corresponding configuration file is stored in a local memory of said next one of said plurality of servers identified by the predefined uniform resource locator (URL) and contains parameters including variables to be applied for configuring a load balancing scheme implemented by said load balancer, and said load balancer waits for a reply from said next one of said plurality of servers;
means for receiving either said corresponding configuration file formatted into a markup language supported by the load balancer or an error message from said next one of said plurality of servers; and
means for validating parameters in said corresponding configuration file if received;
means for configuring said load balancer to dispatch client requests among said plurality of servers based on a load balancing algorithm defined by said parameters including said variables obtained from said configuration files; and
means for dispatching requests received via said network to said plurality of servers in accordance with said algorithm.
10. A computer readable product embodied on computer readable media readable by a computing device for configuring a scheme for balancing the servicing of client requests in a server farm comprising:
computer readable program code configured to initialize a load balancer by identifying to said load balancer, address information for a plurality of servers in a server farm;
computer readable program code configured to individually poll each of the plurality of servers by the load balancer so as to obtain a configuration file from each polled server if available, wherein:
each obtained configuration file contains the parameters necessary to configure the load balancer for bringing the associated polled server on-line; and
polling is implemented by repeating for each of said plurality of servers by:
computer readable program code configured to select by said load balancer, a next one of said plurality of servers;
computer readable program code configured to send a request across a corresponding network from said load balancer to said next one of said plurality of servers for a corresponding configuration file by specifying a predefined uniform resource locator (URL) using a standard network protocol request, wherein the corresponding configuration file is stored in a local memory of said next one of said plurality of servers identified by the predefined uniform resource locator (URL) and contains parameters including variables to be applied for configuring a load balancing scheme implemented by said load balancer;
computer readable program code configured to wait for a reply from said next one of said plurality of servers;
computer readable program code configured to receive either said corresponding configuration file formatted into a markup language supported by the load balancer or an error message from said next one of said plurality of servers; and
computer readable program code configured to validate parameters in said corresponding configuration file if received; and
computer readable program code configured to configure a load balancing algorithm by said load balancer in accordance with said parameters that were read out of each corresponding configuration file.
2. The method of
3. The method of
4. The method of
5. The method of
6. The method of
7. The method of
8. The method of
initializing the load balancer by manually inputting the address information of each one of said plurality of servers;
polling each one of said plurality of servers for said configuration file pertaining to each of said servers; validating each of said configuration files; and
configuring the load balancing algorithm based on said parameters in said configuration files.
9. The method of
storing configuration files provided by a server manufacturer.
11. The product of
12. The product of
13. The product of
14. The product of
computer readable program code configured to initialize the load balancer by reading manually inputted address information of each one of said plurality of servers;
computer readable program code configured to poll each one of said plurality of servers for said configuration file pertaining to each of said servers; and
computer readable program code configured to validate each of said configuration files for configuring said load balancer to dispatch client requests among said plurality of servers.
15. The product of
computer readable program code configured to obtain configuration files provided by a server manufacturer.
17. The computing apparatus of
18. The computing apparatus of
19. The computing apparatus of
means to initialize the load balancer based upon manually inputted address information of each one of said plurality of servers;
means to poll each one of said plurality of servers for said configuration file pertaining to each of said servers; and
means to validate each of said configuration files for configuring said load balancer to dispatch client requests among said plurality of servers.
20. The computing apparatus of
|
The invention pertains to load balancing at a server farm in a distributed network. More particularly, the invention pertains to a method and apparatus for dynamically configuring a load balancing scheme.
In the case of the Internet and the World Wide Web (Web), client machines run programs called Web browsers that enable one to access and view Web pages by issuing requests for that information from a particular server. Such requests are routed through the Internet 114 to the server identified in the request (by its URL) and return the requested information (if available) to the requesting client machine 112 through the Internet 114.
A large-scale server farm is illustrated at 116a in
The number of ways that a network operator or Web site operator can divide computing tasks among multiple servers is virtually limitless. However, there are two primary types of divisions of servers, namely, division among server groups and division among server clones within a server group. Usually, each server group contains one or more servers capable of handling a certain subset of tasks within the server farm. A server group comprises more than one server, wherein each server in the group is a clone of each other server in the group whereby each clone is equally capable of servicing a request. In
For instance, let us assume that server farm 116a forms the Web site of a single, large-scale retailer and that server group 120 comprises an application server group. The application server group 120 performs tasks such as dynamically building Web pages responsive to requests received from clients surfing through the Web site and enabling the selection of goods for purchase. A second application server group 122 comprising server clones 122a and 122b which run a different set of applications and thus handle a second type of client requests. For example, when a person is finished shopping and is ready to “check out”, the client requests corresponding to checking out after having selected items for purchase are handled by server group 122 which handles the back-end business tasks such as creating an invoice, creating a bill of lading, checking inventory to determine if the ordered items are in stock, checking credit card information to confirm validity and the availability of sufficient credit for the purchase, determining shipping costs and taxes, and calculating a total cost for the purchased items.
A third server group 124 comprises a database server 124a that stores data that may be needed by the other server groups to process requests. The database server 124a may store multiple databases such as a database of inventory, a database of the content that is used for dynamically building Web pages, a database for calculating taxes and shipping costs based on the shipping address, a database for maintaining session data, etc. In this example, there is only one database server, server 124a. However, if the traffic to and from the database server 124 is sufficiently high, it could also be a server group comprising two or more server clones in order to properly service the amount of traffic.
When a request is routed to server farm 116a via the Internet 114, the front-end http server 118 receives and parses the request in order to, among other things, determine to which application server the request should be dispatched for servicing. The URL or other information contained within a client request typically indicates the type of request (e.g., check out) and thus will dictate to which server group in a server farm a particular request must be routed. The aforementioned is an example of the “content-based” aspect of routing a request to a particular, appropriate, server group in a server farm. Within a server group, however, a request can be serviced by any one of the clones within that server group. Accordingly, the front-end http server 118 also must also make a determination as to which server clone in the determined server group a request should be dispatched. Accordingly, a front-end http server such as server 118 typically will include a load balancer software module for choosing one of the multiple clones in a server group based on a multiplicity of factors.
One of the more important factors is the amount of traffic the individual server clones in the server group are currently handling. Commonly, it is desirable to distribute requests to servers within a server group such that each server clone handles approximately the same number of requests in a given time period so as to prevent one server from becoming over-loaded while another server is under-utilized. However, other considerations often factor into the load balancing scheme. For instance, during low traffic periods, the opposite may be desirable. That is, it may be desirable to turn off some of the servers that are not needed during periods of low traffic and just have one or a few of the servers running and servicing client requests. Further, some servers may fail partially or entirely, in which case the load balancer will need to adapt the load balancing scheme.
A server farm is a dynamic entity. Particularly, servers may be added to server groups, servers may be taken away from server groups, a series of tasks performed by a single server group may be split into two server groups, a server may go down unexpectedly, etc. In such events, the load balancer needs to be reconfigured in order to most effectively distribute client requests among the servers in the server farm. Accordingly, as the characteristics of the server farm change, the load balancer usually needs to be manually reprogrammed. Even if the load balancing software is sufficiently sophisticated to dynamically alter its algorithm in response to such changes, it at least needs to have the necessary information about each server in the farm manually input to it. Such information might include time of day rules, whether the server is up or down, and health information about the server such as is commonly maintained in health URLs (as is well known to those of skill and the art).
Another parameter that is important to the load balancing algorithm is the session affinity rules applied at the server farm. Particularly, in many types of communication sessions between a particular client and a particular server system (i.e., Web site or server farm), it is desirable to associate multiple client request from a single client to a single Web site (or server farm) with each other so as to be able to maintain state information. For instance, at retail Web sites, which commonly use dynamically generated shopping cart pages to keep track of items being purchased by a particular client, maintaining state information is a necessity in order to keep track of the various products selected for purchase so that a shopping cart page correctly reflecting the items selected for purchase by the individual can be generated. Typically, each instant in which an individual selects another item for purchase will be contained in a different client request. Accordingly, the server system must have some mechanism for associating the different client requests from a given client with each other in order to properly add items to that individual's shopping cart page.
Countless other examples exist in which it is useful or necessary to associate a series of requests from a single client machine with each other and maintain state data for that series of related requests.
Many network applications, including those on the Internet, operate based on a session level protocol. Each message that makes up part of the session is exchanged in requests/response flows, and there are typically many messages exchanged. Each client request is transmitted from a client to a server using standard network protocols, and typically contain no information in the network protocol headers that relates that request to any other request in the session. Thus, in a session-based network application using standard network protocols, there is no provision in the network protocol headers that would allow a server (or client) to maintain session information about a series of related requests.
However, several ways have been developed for maintaining session information in a layer on top of the transfer protocol layer. One of the earliest mechanisms for maintaining session information was the use of cookies. As is well known to those of skill in the art of Web development, cookies are small pieces of data that a server sends to a client machine and that the client machine can thereafter include as part of requests to the same server (or server farm). A cookie can include information identifying a particular session to which the request belongs. The Java programming language also includes more advanced mechanisms such as the javax.servlet.http.HTTPSession object (commonly called HttpSession) for maintaining session information using cookies.
Although many schemes are possible and in use, typically, it is desirable in a server farm for all requests in a given session that are to be serviced by a given server group to be serviced by the same clone within that group. At least one of the reasons that this is beneficial is because, if different requests in a given session are serviced by different servers, then each of those servers must either build or be able to retrieve from a database the same session information. Reading and writing to a database for this purpose creates a substantial amount of additional traffic and overhead processing in the server farm.
Session affinity is a term used for describing rules for attempting to send different requests in a given session to the same server clone in a server group, when possible. Accordingly, the session affinity rules applied within a server farm also must be taken into account in developing a load balancing scheme.
Typically, the data items (parameters) needed by the load balancer to properly route requests to the most appropriate server are manually entered by a human operator. The variables typically take the form of cryptic alphanumeric codes which must be entered exactly for the load balancing software to recognize them. The task is tedious and error prone.
U.S. Pat. No. 6,006,264 discloses a method and system for directing flow between a client and a server that includes some automation of the process of feeding the load balancing algorithm with the necessary parameters for each server. Particularly, it discloses a scheme utilizing a module called an Intelligent Content Probe (ICP) that populates the load balancer with server and content information by probing servers for specific content relevant to load balancing that is not already stored in the load balancer.
It is an object of the present invention to provide an improved method for configuring a load balancer dynamically.
It is a further object of the present invention to provide an improved load balancing scheme.
It is yet another object of the present invention to provide an improved load balancer.
The invention is a method and apparatus for facilitating load balancing in a server farm. In accordance with the invention, the variables necessary for a load balancing program to configure a load balancing algorithm is stored in a file at a predefined URL. The load balancer can query the file, which returns the necessary variables. The load balancer then dynamically configures the load balancing algorithm in accordance with the information returned.
The variables contained in the file (e.g., HTML page) might include server cookies, URL masks for content-based routing, and the health URLs for the server. As necessary, the load balancer can perform a configuration operation for the server farm. The load balancer issues a GET command for the configuration file for each server in the farm. For each positive response to this request, the information is formatted into the markup language supported by the load balancer and returned to the load balancer. The load balancer validates the returned information. Assuming that the information passes the validation process, the parameters contained in the configuration file are passed to the configuration algorithm and the corresponding server is brought on line. The process is repeated for each server for which the load balancer is responsible.
In accordance with the invention, instead of an operator manually entering the variables for each server, the process is largely automated. The individuals items of data needed by the load balancer (parameters) will vary for different load balancing schemes. For instance, in a Web site having only one server group with each clone in that group being able to perform all tasks, the load balancer would not necessarily need to perform any content-based routing. Other factors that would affect the type and amount of data needed by the load balancer in order to perform load balancing include (1) session and or cookie affinity rules, if any applied at the server farm, (2) time of day rules, if any, applied at the server farm, (3) server health information, which is typically made available by polling of a health URL and (4) all content-based rules. The foregoing is merely exemplary and other possible variables would be well known to persons of skill in the art of Web development.
In accordance with the invention, all of the jewels needed by the load balancer are stored in a file, preferably in the data format used by the server farm for communications over the network to which it is coupled. For instance, in a Web server farm, the configuration files might be in HTML or XML format.
In at least one preferred embodiment, the health information remains in a separate health URL and the configuration file contains the health URL (i.e., the address of the file containing the health information, not the health information itself). The load balancer would then retrieve the file at the health URL in a separate GET operation after it determines the health URL from the configuration file.
Also in a preferred embodiment of the invention, each server contains the configuration file in its own memory having a path in accordance with a predefined standard. For instance, that standard path may be the server address in the server farm followed by the file name config.htm.
The invention has at least two major advantages. First, it eliminates the need for the operator of the load balancer to manually enter the information. This saves time and also reduces or eliminates errors in data entry. Secondly, the operator does not need to have in-depth knowledge of the Web site in order to properly configure the load balancer since the manufacturer of the server can provide the information needed by the load balancer within the memories of the servers when they are delivered to the Web site operator.
Either at predetermined intervals or in response to events that are either manually detected or automatically detected by the load balancer, the load balancer can run a configuration (or reconfiguration) operation in which all of the configuration files are polled to retrieve all the variables used in defining the load balancing algorithm. Examples of events that might be automatically detected by the load balancer are a server going down, and instantaneous traffic volume at the server farm. Either of the above also might be manually detected. Examples of events that typically would be manually detected, but could be automatically detected, if desired, include the addition or removal of a server or server group from the server farm and/or the intentional bringing down of a server, such as may be necessary for routine and/or unscheduled maintenance.
Among clones, the variables in the configuration file will largely be the same. One notable exception is that the session affinity cookies will be unique to each server.
In step 104, the load balancer sends an http request, for instance, “GET/_SVR_LB_.CFG HTTP/1.0”, for the configuration file of the particular server which is being polled in this round, where “SVR_LB” is the particular server path.
The load balancer then waits for a reply. In step 108, it determines whether it received a proper reply or a “HTTP/1.0 404 not found” reply. If it receives a 404 reply, flow proceeds to step 116 where the load balancer generates an error report and stores it in an error log in its memory. Flow then returns to step 102 to determine whether there are any other servers that need to be polled.
If, on the hand, the server returns a proper reply in step 108, flow proceeds to step 110, where the load balancer validates the received data. The validation process essentially can comprise checking whether the data is in the proper language and includes an expected minimum set of parameters. If the data is not valid, then flow proceeds to step 116, where error information is written to the error log. Flow then proceeds back to step 102 to determine whether there are any more servers which must be polled.
If, on the other hand, the data is validated in step 110, flow proceeds to step 112. In step 112, the load balancer configures its load balancing algorithm in accordance with the parameters that were read out of the configuration file for that particular server. Flow then proceeds to step 114, where that server is brought on line. Step 114 is not necessarily a function of the load balancing software module. Nevertheless, it is shown in the flow chart for sake of completeness.
Having thus described a few particular embodiments of the invention, various alterations, modifications, and improvements will readily occur to those skilled in the art. Such alterations, modifications and improvements as are made obvious by this disclosure are intended to be part of this description though not expressly stated herein, and are intended to be within the spirit and scope of the invention. Accordingly, the foregoing description is by way of example only, and not limiting. The invention is limited only as defined in the following claims and equivalents thereto.
Delima, Roberto, Lanzen, Craig A.
Patent | Priority | Assignee | Title |
10237340, | Mar 02 2016 | International Business Machines Corporation | Dynamic client-based leader election |
7640298, | Dec 21 2000 | CLOUDROCK LLC | Method and system for communicating an information packet through multiple router devices |
7649876, | Dec 21 2000 | CLOUDROCK LLC | Method and system for communicating an information packet through multiple router devices |
7693176, | Feb 27 2006 | Vonage America LLC | Method and system for bidirectional data transfer |
8209415, | Feb 27 2009 | Yottaa Inc | System and method for computer cloud management |
8341290, | Dec 21 2000 | CLOUDROCK LLC | Method and system for selecting a computing device for maintaining a client session in response to a request packet |
8358626, | Jan 06 2005 | NTT DOCOMO, INC. | Mobile device, content distribution system, and content distribution method |
8380832, | Jul 24 2001 | International Business Machines Corporation | Dynamic HTTP load balancing |
8412807, | Jul 24 2001 | International Business Machines Corporation | Dynamic HTTP load balancing |
9058252, | Mar 24 2010 | Microsoft Technology Licensing, LLC | Request-based server health modeling |
9100409, | Dec 21 2000 | CLOUDROCK LLC | Method and system for selecting a computing device for maintaining a client session in response to a request packet |
9154549, | Oct 27 2011 | Cisco Technology, Inc. | Dynamic server farms |
9374273, | Jul 24 2001 | International Business Machines Corporation | Dynamic HTTP load balancing |
9716627, | Jul 24 2001 | International Business Machines Corporation | Dynamic HTTP load balancing |
9930110, | Mar 02 2016 | International Business Machines Corporation | Dynamic client-based leader election |
Patent | Priority | Assignee | Title |
6006264, | Aug 01 1997 | Cisco Technology, Inc | Method and system for directing a flow between a client and a server |
6023722, | Dec 07 1996 | International Business Machines Corp. | High-availability WWW computer server system with pull-based load balancing using a messaging and queuing unit in front of back-end servers |
6078960, | Jul 03 1998 | Rovi Technologies Corporation | Client-side load-balancing in client server network |
6286038, | Aug 03 1998 | CIENA LUXEMBOURG S A R L ; Ciena Corporation | Method and apparatus for remotely configuring a network device |
6393458, | Jan 28 1999 | SAP SE | Method and apparatus for load balancing in a distributed object architecture |
6560717, | Dec 10 1999 | Oracle OTC Subsidiary LLC | Method and system for load balancing and management |
7197547, | May 11 1999 | June Ray Limited | Load balancing technique implemented in a data network device utilizing a data cache |
20020129127, | |||
20030154279, |
Executed on | Assignor | Assignee | Conveyance | Frame | Reel | Doc |
Jul 17 2001 | DELIMA, ROBERTO | International Business Machines Corporation | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 012028 | /0216 | |
Jul 17 2001 | LANZEN, CRAIG A | International Business Machines Corporation | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 012028 | /0216 | |
Jul 24 2001 | International Business Machines Corporation | (assignment on the face of the patent) | / |
Date | Maintenance Fee Events |
Dec 17 2008 | ASPN: Payor Number Assigned. |
Apr 03 2012 | M1551: Payment of Maintenance Fee, 4th Year, Large Entity. |
Jul 18 2016 | M1552: Payment of Maintenance Fee, 8th Year, Large Entity. |
Jul 17 2020 | M1553: Payment of Maintenance Fee, 12th Year, Large Entity. |
Date | Maintenance Schedule |
Jan 20 2012 | 4 years fee payment window open |
Jul 20 2012 | 6 months grace period start (w surcharge) |
Jan 20 2013 | patent expiry (for year 4) |
Jan 20 2015 | 2 years to revive unintentionally abandoned end. (for year 4) |
Jan 20 2016 | 8 years fee payment window open |
Jul 20 2016 | 6 months grace period start (w surcharge) |
Jan 20 2017 | patent expiry (for year 8) |
Jan 20 2019 | 2 years to revive unintentionally abandoned end. (for year 8) |
Jan 20 2020 | 12 years fee payment window open |
Jul 20 2020 | 6 months grace period start (w surcharge) |
Jan 20 2021 | patent expiry (for year 12) |
Jan 20 2023 | 2 years to revive unintentionally abandoned end. (for year 12) |