A Periodic Dynamic Load Balancing Method

Total Page:16

File Type:pdf, Size:1020Kb

A Periodic Dynamic Load Balancing Method

INTRODUCTION

The rapid growth of network traffic requires servers to have the ability of providing a large number of concurrent accesses. The processing and I/O ability of servers becomes a bottleneck of providing the service. In order to solve the problem, NCSA of US UIUC first put forward the concept of server cluster, who also realized an

A periodic dynamic load balancing method

Taotao Fan* & Alex Grey Institution of Information Engineering, China Academy of Sciences, Beijing, China Xiaoqi Jia University of Chinese Academy of Sciences, Beijing, China

ABSTRACT: A periodic load balancing method is proposed according to the load imbalance of network server in a clustered system of high concurrency. It is divided into different load periods based on the load condition of server node. Corresponding load balancing strategy is adopted for each period that the strategy of fast select is used in the period of small load while the server node with stable response time is first adopted in the period of large load. Periodic load strategy avoids the load imbalance caused by the single load strategy. It can be known from the experimental comparison that the improved periodic load balancing strategy is superior to the load balancing strategy of weighted least connection.

Keywords: cluster technology; load balancing; periodic choice original system NCSA SScalable Web Cluster [1]. After this, the cluster technology is widely used. The server cluster composed by multiple back-end servers provides services as a single, largely improving the quality of network service. Whether a large number of concurrent requests can be reasonably distributed to back-end service nodes or not is a key factor that influences the cluster technology. This process is called load balancing. With the development of the load balancing technology, some new load balancing algorithms are proposed by researchers at home and abroad. These load balancing algorithms can be generally divided into static algorithms and dynamic algorithms. Static algorithms, represented by LVS of Doctor Wensong Zhang, mainly include roll polling algorithm, weighted roll polling algorithm, least connection algorithm, Hash, etc. Static algorithms are simple without regard to actual load conditions of real nodes. It performs excellently at the request of low concurrency while causes imbalanced load and efficiency decrease under high concurrency. The dynamic load strategy takes into account actual load condition of the current service node. Researches of recent years mainly involve dynamic load balancing. The dynamic load balancing algorithm applied in cloud virtual machine is put forward in literature [3]. Two indexes, real-time response time and free resource, are inspected in this algorithm and a queue including node weight factors is constructed according to the two indexes. A new load balancing method used in Linux cluster system is proposed in literature [4]. The method of authoritative command packet and information packet is adopted in the cluster system. Each node sends out information packets of its own load in a certain period. Nodes receiving authoritative command packets construct a load distribution table according to information packets and send out load commands. Nodes receiving load commands will execute these load commands. An effective self-adaptive load balancing algorithm that can be applied in the peer-to-peer network is put forward in literature [5]. This algorithm automatically establishes a binary tree for backup nodes and then dispatches extra query tasks to backup nodes. The dynamic load balancing algorithm applied in cloud virtual machine is put forward in literature [3]. Two indexes, real-time response time and free resource, are inspected in this algorithm and a queue including node weight factors is constructed according to the two indexes. A new load balancing method used in Linux cluster system is proposed in literature [4]. The method of authoritative command packet and information packet is adopted in the cluster system. Each node sends out information

*Corresponding author: [email protected] packets of its own load in a certain period. Nodes period of moderate load and the period of large load. receiving authoritative command packets construct a Load adjusting strategies that are the most favorable to load distribution table according to information each period are adopted so as to shorten the response packets and send out load commands. Nodes receiving time and improve the quality of network service. load commands will execute these load commands. An effective self-adaptive load balancing algorithm that can be applied in the peer-to-peer network is put A PERIODIC DYNAMIC LOAD BALANCING forward in literature [5]. This algorithm automatically establishes a binary tree for backup nodes and then 1.1 Selection of load indexes dispatches extra query tasks to backup nodes. Weighted roll polling algorithm is a representative In load decision, it is very important to select indexes of the frequently-used static algorithms. In the that are able to reflect load conditions of server nodes realization of LVS in literature [2], CPU frequency, effectively. It can be found from relevant studies and memory capacity and the network card IO speed are theses that a commonly used dynamic load index at taken into account and weights are configured as 0.5, present is the utilization rate of resource, such as CPU 0.3 and 0.2. The weighted polling distribution usage rate, memory usage rate, IO frequency per algorithm can be realized simply with easy second, etc. As for the selection of load index in this configuration. However, if the access flow is paper, two aspects are mainly taken into account: (1) excessively large during the operation, servers with whether the index is able to reflect the current load large initial weights will be in a state of high load condition of server nodes or not; (2) whether the continuously that might cause a downtime while complexity and time consumption of collecting and servers with small initial weights might be idle for a processing the index information will increase load or long time that causes resource waste. In order to fully not. reflect the real-time load condition of back-end In this study, two dynamic indexes are selected servers, the author of literature [9] divided requests based on the above two points: the number of current into four categories according to specific contents: 1) connections and request response time of server. 1) Static requests, mainly including HTML static pages The number of current connections. It fails to reflect and using memory resources during processing. 2) the load condition of nodes accurately due to different Ordinary requests, mainly including dynamic objects resources required by the processing of each generation and database operations and using IO and connection. But it has an obvious advantage that it can memory during processing. 3) Security requests, be easily obtained. Other dynamic indexes, such as mainly including online payment and network bank CPU usage rate and memory usage rate, can be only and using CPU resource. 4) Related requests of obtained through extra communications and data multimedia, mainly including video and audio processing. The acquisition of the current connections requests and using IO resource. Real-time dynamic number costs nothing. It only needs to record because load indexes like CPU usage rate, memory usage rate, all requests and feedbacks pass through the load IO queue size and IO request frequency are extracted balancer. 2) Request response time. Most dynamic from back-end server nodes during the processing. load strategies take into account request response Service nodes that are most suitable for the current time, which reflects the comprehensive load condition request are then selected in line with the category of of a server on the whole. There are many work queues the current request. The load balancer is on the only in a kernel. The response time will increase way that must be passed by network flow, so a large exponentially if an index of nodes is overloaded. number of network requests have already led to the Besides, the response time of a request can be easily overload of the load balancer when the flow is high. In obtained only by recording the request transmitting addition, acquisition, calculation and transmission of time Ts and the response returning time Te. the dynamic information will make the load balancer a bottleneck because it is difficult to make a choice, 1.2 Global idea of the design influencing the service quality of the whole network. This paper focuses on exploring a periodic load General logic of each request is presented as below: balancing method. The feature that network flow (1) Each request will be given an opportunity to presents a wave form is discussed in literature [10]. choose. There are N (the number of server nodes) That is to say, a wave of large flow would appear after opportunities to choose in each polling. The optimal a small flow for a long time. If change features of server in this load period will be chosen in each network flow are not taken into account, a single load opportunity. strategy for the whole process will cause server (2) If the server returns a wrong response or refuses resource waste or excessive load transfer to the load to respond after a certain choice of this polling, the balancer. In this study, the request processing of the server is marked as the one that has been chosen in back-end server is divided into three different periods this polling. And the auxiliary variable fails is used to according to load indexes, the period of small load, the record the number of failures of the server during this period, which is one of the bases judging whether the current node load and the utility ratio of connections is node can choose again or which load period is the described in Figure 2: node in. (3) Each server has a fixed fail timeout. If node fails exceeds the max fails within the fail timeout, the server is in the state of no selection. The value of fail can be reduced if the time interval from the last fail exceeds the fail timeout. It means that the load is reduced after a period of time and the server is able to participate in load selection. The overall logic flow chart is shown in Figure 1:

Figure 2. The relationship between current node load and the utility ratio of connections

It can be seen from Figure 2 that the larger the utility ratio is, the larger the node load is. The relationship between load and fail times is shown in Figure 3:

Figure 3. The relationship between load and fail times Figure 1. Flow chart of node load selection It can be seen from Figure 3 that the time of fails 1.3 Periodic load balancing method goes up exponentially when the load exceeds 65%. According to the relationship between the utility In the process of load balancing, the server state can ratio and fail times and the current node load, the logic be divided into three periods according to load judging the current node is presented in Table 1: performance indexes. The key idea is to select the server node of the smallest load rapidly with the Table 1. Judgment table of load period maximum probability. Nodes are selected in the period Load condition fairs=max_fairs of small load if there are nodes in the period of small M=M Moderate load Large load the period of moderate load or in the period of large idle load. It can be seen from Table 1 that it will be judged as Here is the deduction about the judgment on server the period of large load regardless of the utility value load according to literature [11]: L= λ *cpu +λ *mem 1 u 2 u of connection if the fail time exceeds the preset +λ *net ; cpu is the utilization rate of CPU; mem is 3 u u u maximum fail time. It is judged as the period of small the usage rate of memory; net is the usage rate of u load when the utility value of connection is smaller network bandwidth; λ , λ , λ are respectively 0.5, 0.3 1 2 3 than the preset idle utility value M . In this and 0.2. idle experiment, the idle utility value M is 65%. Each node is provided with a maximum number of idle affordable connections Cmax in line with the initial hardware performance. According to the number of 1.3.1 Selection process of the small load period If it is judged through load indexes that a server is in current connections Ccur, the utility ratio of current the small load period, the current load balancing connections is M= Ccur/Cmax. The relationship between strategy should be simple and fast as much as possible. Most resources of the server are idle. The EXPERIMENTAL TEST node satisfying the minimum utility value of connection M will be selected as the server node. 1.4 Experimental environment

1.3.2 Selection process of the moderate load period In order to test the periodic load strategy, five test In moderate period, resource utilization rate of each machines are selected for this experiment. The load server node is stable and the optimal node can be balancer Nginx is carried by a physical machine. selected. The initial load capacity and the fail time Other three test machines are used as back-end server should be combined to carry calculate physical machines. And the other one test machine is comprehensively. The real weight is: used as a client for interview test. The experimental environment layout is shown in Figure 4: (1)

The larger the fail time is, the smaller the real weight will be. Regarding the utility value of connection, each server in the moderate load period is provided with a real load score:

(2)

Load score reflects the overall load condition of the current server in the moderate load period. The optimal node should be selected from the server with the smallest load score. Figure 4. Diagram of experimental environment 1.3.3 Selection process of the large load period If the fail time of the node satisfies fails>=max_fails, the node is in the period of large load no matter where Two types of requests are simulated in the the utility value is (the number of connections is experiment, requests of small flow data and requests unable to reflect the real load condition). It is now of large flow data, namely requests for static pages necessary to check the response time R of the node in and requests for videos. So, video data of 630M are a recent period of time. Response time can reflect uploaded on the server. node load more clearly in the condition of large load. The scene graph of the experiment is shown in Table 2. As for the node Si, m times of correct response time In the experiment, PLB strategy (periodic load (success response of request) are preserved and the balancing strategy) is compared with WLC (weighted time matrix is shown below: least connection strategy).

(3) Table 2. Scene graph of the experiment Remove nodes whose average response time is Users Average Percentage Percentage speed of of small data of large data longer than the overall average response time. The request (r/s) request request average response time of node i is: Scene1 500 400 100% 0% Scene2 500 200 50% 50%

Calculate the variance of each node: 1.5 Test result Test result of scene 1:

The variance reflects the smoothness of the last response time on the whole. A load score is provided in line with the current utility value of connection after the variance is concluded:

Here, k1, k2={0.3,0.7}. It is regarded that the stability of the server has more influence on the selection result. The node with the lowest load score is regarded as the optimal. Figure 5. WLC strategy of scene 1 CONCLUSION

A periodic load balancing method is put forward in this paper. According to the utility value and fail time of each node in the loading period, back-end nodes can be divided into three different load periods. Load strategies that are suitable for the periodic features should be adopted for different load periods. The weighted least connection strategy and the periodic load balancing strategy are compared through an experiment. The periodic load balancing strategy can distribute loads to back-end nodes in a more balanced way, which verifies the validity.

Figure 6. PLB strategy of scene 1 REFERENCES

In scene 1, all the requests are small flow data [2] Dias D M, Kish W, Mukherjee R, et al. 1996. A requests. The load percentage of each node is recorded scalable and highly available web server, Compcon'96.' every 5 seconds. It can be seen from Figure 5 and 6 Technologies for the Information Superhighway' that the load of each server in PLB strategy tends to be Digest of Papers. IEEE, pp: 85-92. the average load compared to WLC strategy. It means [3] Zhang, W.S.. Linux Server Cluster System, that PLB strategy is more excellent in load balancing. www.linuxvirtualserver.org. [4] Bhatia J, Patel T, Trivedi H, et al. 2012. HTV dynamic Test result of scene 2: load balancing algorithm for virtual machine instances in cloud, Cloud and Services Computing (ISCOS), 2012 International Symposium on. IEEE, pp: 15-20. [5] Patil S, Gopal A. 2012. Need of new load balancing algorithms for linux clustered system, International Conference on Computational techniques And Artificial intelligence (ICCTAI’2012) (ISBN 978-81- 922428-5-9) Penang Maleshia in year Jan.. [6] Xiong N, Xu K, Chen L, et al. 2012. An effective self- adaptive load balancing algorithm for peer-to-peer networks, Parallel and Distributed Processing Symposium Workshops & PhD Forum (IPDPSW), 2012 IEEE 26th International. IEEE, pp: 1425-1432. [7] Wu Y, Luo S, Li Q. 2013. An adaptive weighted least- load balancing algorithm based on server cluster, Figure 7. WLC strategy of scene 2 Intelligent Human-Machine Systems and Cybernetics (IHMSC), 2013 5th International Conference on. IEEE, 1: 224-227. [8] Zhang M, Yu H. 2013. A new load balancing scheduling algorithm based on linux virtual server, Computer Sciences and Applications (CSA), 2013 International Conference on. IEEE, pp: 737-740. [9] Zongyu X, Xingxuan W. 2014. A modified round- robin load-balancing algorithm for cluster-based web servers, Control Conference (CCC), 2014 33rd Chinese. IEEE, pp: 3580-3584. [10] Tiwari A, Kanungo P. 2010. Dynamic load balancing algorithm for scalable heterogeneous web server cluster with content awareness, Trendz in Information Sciences & Computing (TISC), 2010. IEEE, pp: 143- 148. Figure 8. PLB strategy of scene 2 [11] Stallings W. 1997. Viewpoint: Self-similarity upsets data traffic assumptions, IEEE spectrum, 34(1): 28-29. [12] Zhang, W.S. Load Scheduling of LVS Cluster, The load condition of each node is recorded every 5 www.linuxvirtualserver.org/zh/lvs4.html. seconds. It can be seen from Figure 7 and 8 that PLB [13] Li, K. & Wang, B.J. 2009. A study on server cluster strategy can better balance the load of back-end nodes load balancing technology and algorithm comparison, for mixed type of requests. Computer & Modernization, (8): 7-10. [14] Wang, S., Xiu, B.X. & Xiao, W.D. 2004. A study on server cluster load balancing algorithm, Computer Engineering and Applications, 40(25): 78-80. [15] Li, Y.B., Zhu, S., Chang, Z.G., et al. 2014. Overview of server cluster technology, Management & Technology of SME, (2): 296-296.

Recommended publications