Home >Operation and Maintenance >Linux Operation and Maintenance >What is load balancing? A brief introduction to load balancing

What is load balancing? A brief introduction to load balancing

青灯夜游
青灯夜游forward
2019-03-28 14:38:009530browse

The content of this article is to introduce load balancing, understand what load balancing is, the advantages of load balancing, etc. It has certain reference value. Friends in need can refer to it. I hope it will be helpful to you.

1. What is load balancing

Load Balance means to allocate execution to multiple operating units, such as Web servers, FTP servers, enterprise key application servers and other mission-critical servers, etc., to complete work tasks together.

If you understand it literally, it can explain that N servers share the load evenly, and a certain server will not be idle because of a high load on a certain server. Then the premise of load balancing is that it can be achieved by multiple servers, that is, more than two servers are enough.

Load balancing is built on the existing network structure. It provides a cheap, effective and transparent method to expand the bandwidth of network devices and servers, increase throughput, strengthen network data processing capabilities, and improve network flexibility. and availability.

2. Advantages of load balancing

Reduce the pressure on the server and distribute the traffic originally required by one server to multiple servers. And improve the availability of the project. When a server hangs up, the project will not be paralyzed.

Three and four-layer load balancing and seven-layer load balancing

Four-layer load Balance works in the transport layer of the OSI model, and its main job is forwarding. After receiving the client's traffic, it forwards the traffic to the application server by modifying the address information of the data packet.

Seven-layer load balancing works in the application layer of the OSI model, because it needs to parse application layer traffic, so after receiving the client's traffic, the seven-layer load balancing also needs a complete TCP/IP protocol stack. Seven-layer load balancing will establish a complete connection with the client and parse the application layer request traffic, then select an application server according to the scheduling algorithm, and establish another connection with the application server to send the request. Therefore, seven-layer load balancing The main job is to act as an agent. Seven-layer load balancing is also called "content switching", which mainly determines the final selected internal server through the truly meaningful application layer content in the message, coupled with the server selection method set by the load balancing device.

Advantages of seven-layer load balancing: This method can modify the client's request and the server's response in any sense, which greatly improves the flexibility of the application system at the network layer. sex; high safety.

Seven-layer load balancing mainly focuses on the widely used HTTP protocol, so its application scope is mainly systems developed based on B/S such as numerous websites or internal information platforms. Layer 4 load balancing corresponds to other TCP applications, such as ERP and other systems developed based on C/S.

4. Load balancing software

Load balancing software including Nginx, LVS, HaProxy, etc. are currently in use The three most widespread load balancing software.

5. Load balancing algorithm

1. Round Robin: It is the simplest way to send requests to all backends in turn. It is also the default allocation method;

2. Least Connections (least_conn): Track and backend the current number of active connections. The smallest number of connections indicates that the backend has the lightest load. Allocate requests to him. This method will Taking into account the weight information assigned to each upstream in the configuration;

3. Least Time (least_time): The request will be assigned to the backend with the fastest response and the smallest number of active connections;

4 , IP Hash (ip_hash): Calculate the hash value for the request source IP address. IPv4 will consider the first 3 octets, and IPv6 will consider all address bits, and then assign it to the backend through some mapping based on the obtained hash value;

5. Generic Hash (hash): Calculate the hash value to complete the distribution based on user-defined resources (such as URL). Its optional consistent keyword supports consistent hash features;

6. Load balancing based on DNS

Usually a modern network server domain name will be associated with multiple hosts. When performing a DNS query, by default the DNS server will use round The -robin mode returns the list of IP addresses in a different order, so client requests are naturally distributed to different hosts. However, this method has inherent flaws: DNS does not check the accessibility of the host and IP address, so the IP assigned to the client is not guaranteed to be available (Google 404); the DNS resolution results will vary between the client and multiple intermediate DNS servers are constantly caching, so the allocation of backends will not be ideal.

Recommended video tutorials: "Linux Tutorial"

The above is the entire content of this article, I hope it will be helpful to everyone's study. For more exciting content, you can pay attention to the relevant tutorial columns of the PHP Chinese website! ! !

The above is the detailed content of What is load balancing? A brief introduction to load balancing. For more information, please follow other related articles on the PHP Chinese website!

Statement:
This article is reproduced at:cnblogs.com. If there is any infringement, please contact admin@php.cn delete