Load Balancers 101: Network vs. Application | Traefik Labs (2024)

Computer networking, the way computers link together to share data, has always been an integral part of computing. Without a means to load balance traffic across a network, a computer has little use in daily life. Networking enables the internet and the SaaS-based applications that come with it.

What is a load balancer?

A load balancer is a mechanism in both cloud and on-premises networking architectures that calculates how to distribute traffic across multiple servers, applications, services, or clusters and defines to which instance a given request will travel. It manages the flow of information between servers (which could be physical or virtualized, and in on-prem or cloud environments) and endpoint devices (which could be a smartphone, laptop, or any IoT device).

Load Balancers 101: Network vs. Application | Traefik Labs (1)

Load balancers form a crucial part of any network, and distributed systems cannot function without them. Load balancers create balance by ensuring each server receives an appropriate amount of load from end-users. They prevent some servers from bearing too much load and failing or slowing the application as a result, while other servers receive too little or no load. Some load balancers can perform health checks on servers to check the current and maximum capacity of a server, using this information to distribute traffic fairly between servers. Effective load balancers optimize application performance and availability.

Having a load balancer in our network has significant benefits:

  • Reduces downtime: Incoming requests are processed by more than one backend server, which helps us to build high available environments and less prone to failure of one server
  • Scalability: Having more backend servers allows us to handle more load
  • Flexibility: We can implement more advanced techniques to distribute network traffic and design more reliable environments .

Load Balancers 101: Network vs. Application | Traefik Labs (2)

Expert Guide: Load Balancing High Availability Clusters with TraefikExplore key network configurations for on-prem environments.Download Now

Layer 4 vs. layer 7 load balancing

Load balancing has its roots in the 1990s when hardware appliances distributed traffic across networks. As information technology has become increasingly virtualized, load balancers have progressed into software. Load balancing today exists in both the transport and application layers of the Open Systems Interconnection (OSI) model, which is a standardized reference for how applications communicate over a network.

Load Balancers 101: Network vs. Application | Traefik Labs (3)

Layer 4 Load Balancing

Layer 4 is the transport layer of a network, and its load balancers send network packets to and from servers based on the port and IP addresses of the clients sent in the connection. The client routes the connection to the load balancer, which analyzes and sends the connection to the correct backend server.

A layer 4 load balancer doesn’t have visibility into the content of the connection itself, which is often encrypted. The client cannot see which server a connection has been routed to. Layer 4 load balancers use Transmission Control Protocol (TCP) or User Datagram Protocol (UDP) packets to transmit connections. Both are conventions for simulating connections and handling packets.

Layer 7 load balancing

Layer 7 is the application layer in the OSI model, and it includes many different sorts of applications, such as HTTP, MQTT, SSH, FTP, SMTP, POP3, and IMAP. More often than not, layer 7 load balancers transport HTTP requests. What is special about layer 7 load balancers is that they have visibility into the actual payload of a request.

Layer 7 load balancers route network traffic in a much more sophisticated way than layer 4 load balancers, but they require far more CPU and can reduce performance and increase cost as a result. It’s up to you to evaluate which is better for your use case.

Advanced Kubernetes load balancing

Load balancing becomes particularly complicated when performed in containerized applications that consist of many separate components. Different systems will therefore layer themselves on top of one another to provide advanced load balancing rules.

In layer 7, Kubernetes has its own way of configuring load balancing between multiple backends, and this concept is ingress controllers. Layer 4 load balancing is generally taken care of by the public cloud provider, as each has its own load balancing system. Organizations managing environments on-prem take care of those load balancing capabilities themselves.

Load Balancers 101: Network vs. Application | Traefik Labs (4)

In Kubernetes, ingress controllers differentiate themselves by offering advanced load balancing capabilities. Instead of just transmitting data between the end user and the application, advanced load balancing capabilities allow you to perform rate limiting load balancing, which means you can make the most of your infrastructure and the resources it consumes.

What is rate limiting?

Rate limiting is an advanced form of traffic shaping, which is essentially how you control the flow and rate of traffic coming into your application from the internet. Rate limiting middleware allows you to match the flow of traffic to your infrastructure’s capacity. This carries two big advantages.

Firstly, rate limiting allows you to make sure your infrastructure never becomes overloaded with requests and lags before failing. Without rate limiting, traffic entering your application would line up in a queue and create congestion in your reverse proxy. Likewise, rate limiting is an essential part of any security strategy as it minimizes the effects of DDoS attacks on an infrastructure.

Similarly, rate limiting gives you the ability to make sure traffic is distributed evenly between different servers. It means you can make sure certain proxies don’t receive more traffic than they should compared to others and that your proxies don’t favor certain sources of traffic from the internet over others.

How does rate limiting work? At its simplest, rate limiting middleware lives within your reverse proxy, which sits in between the internet and your microservices. Traffic coming in from the internet is filtered through your rate limiting middleware. If your services are receiving more traffic than they can healthily accommodate, your rate limiting middleware will bounce all incoming requests back to their source. Your rate limiting middleware will also make sure the traffic being filtered out is distributed well amongst your many services.

Let’s illustrate an example of rate limiting. You can configure your middleware to allow, for example, ten requests per second with a maximum burst of fifty requests. When your middleware is holding fifty requests, it will automatically bounce any new requests. Likewise, you can configure sources to say, for example, ten requests can be received from Source A and ten from Source B.

What are other examples of advanced load balancing?

Rate limiting is an example of a technique that accelerates advanced Kubernetes architectures. There are also advanced load balancing mechanisms that ingress controllers enable. Some of them include:

  • Weighted load balancing: Weighted load balancers allow users to define a weight for each server and rebalance traffic when a given server becomes overly crowded. It gives users a fair amount of control at any given moment.
  • Round robin load balancing: Round robin load balancers rotate which server a request will be routed to. Traffic is directed to Server A, then Server B, and then Server C before repeating the cycle all over again. Round robin load balancers send the same amount of requests to each backend regardless of its health. This mechanism is ideal when servers match each other in capacity.
  • Least connection load balancing: This mechanism directs traffic to the server with the fewest active connections in the back end. It is ideal when there are a large number of persistent connections in the traffic unevenly distributed between servers.
  • Mirror load balancing: Traffic Mirroring copies inbound and outbound traffic from the network interfaces that are attached to your instances.

This list includes some of the most popular load balancing mechanisms, but there are many more out there. Many applications will use several load balancing mechanisms at once.

Your choice of ingress controller will affect your load balancing capabilities. Traefik Proxy automates load balancing, including a powerful set of middlewares for both HTTP and TCP load balancing. It includes weighted round robin, round robin, and mirror mechanisms. For organizations with complex distributed systems, Traefik Enterprise includes advanced features. Load balancers are integral to any computer networking strategy. If you want to see Traefik Enterprise in action, don’t hesitate to contact us and book a demo to discover how Traefik Enterprise can work for you.

Load Balancers 101: Network vs. Application | Traefik Labs (5)Load Balancers 101: Network vs. Application | Traefik Labs (6)

Take your network to the next levelJoin our free Advanced Load Balancing Academy class and learn how to modernize and customize your load balancing with Traefik Proxy.Sign Up Today

References and further reading

Load Balancers 101: Network vs. Application | Traefik Labs (2024)

FAQs

Load Balancers 101: Network vs. Application | Traefik Labs? ›

Load balancers create balance by ensuring each server receives an appropriate amount of load from end-users. They prevent some servers from bearing too much load and failing or slowing the application as a result, while other servers receive too little or no load.

What is the difference between network and application load balancer? ›

These load balancers use different types of algorithms to distribute traffic evenly to their targets. An ALB uses a round-robin algorithm by default, routing traffic one after another. However, an NLB uses a flow hash algorithm so that traffic is routed to specific targets in a predetermined manner.

Which load balancing algorithm is the best? ›

Round-robin load balancing is the simplest and most commonly-used load balancing algorithm.

Which load balancer is better? ›

HAProxy. HAProxy is a popular open-source load balancer and reverse proxy widely used to distribute incoming traffic across multiple servers or applications. It is known for its high performance and low resource usage, making it a good choice for environments with high traffic or limited resources.

What is the difference between application load balancer and Network Load Balancer in Azure? ›

Two common types of load balancing are network load balancing and application load balancing. Each differs by whether it operates at Layer 4 or Layer 7 of the seven-layer OSI model.

Why use NLB over ALB? ›

Choosing Between ALB and NLB

Protocol and Routing Requirements: If your application requires complex routing based on the content of the HTTP/HTTPS headers or needs WebSocket support, choose ALB. If your application primarily uses TCP or UDP and benefits from low latency and high throughput, go with NLB.

What are the disadvantages of Network Load Balancer? ›

Disadvantages of load balancing

These include: Complexity: Implementing and managing a load balancing solution, especially in large and dynamic environments, can be complicated. This complexity often requires specialized knowledge and can increase hardware, software, and labor costs for setup and ongoing maintenance.

What are the three types of load balancers in AWS? ›

Further aiding your availability, AWS Elastic Load Balancing supports three types of load balancers: Application Load Balancers, Network Load Balancers, and Classic Load Balancers. You can load each based upon your needs.

What is the least connection method in load balancing? ›

Least connection: Checks which servers have the fewest connections open at the time and sends traffic to those servers. This assumes all connections require roughly equal processing power.

What load balancer does Netflix use? ›

Netflix's Load Balancer - Zuul

Netflix runs on AWS. It has millions of active users, and every user connects with their backend services through a load balancer called Zuul.

When to use classic load balancer vs application load balancer? ›

But in general, the Classic Elastic Load Balancer is likely to be the best choice if your routing and load balancing needs can all be handled based on IP addresses and TCP ports. In contrast, the AWS Application Load Balancer can address more complex load balancing needs by managing traffic at the application level.

Is NLB layer 3 or 4? ›

NLB operates in Layer 4 (the transport layer).

When to use network load balancer? ›

When to Use Network Load Balancer
  1. A demand for seamless support of high-volume or spiky inbound TCP requests.
  2. A need to support an elastic or static IP address.
  3. To support more than one port on an EC2 instance while using container services.

What are the 3 types of load balancers in Azure? ›

Public Load Balancers are used to load balance internet traffic to your VMs. An internal (or private) load balancer is used in scenarios where private IPs are needed at the frontend only. Internal load balancers are used to load balance traffic inside a virtual network.

What are the different types of network load balancers? ›

Traffic type
Load balancer typeTraffic type
Application Load BalancersHTTP or HTTPS
Passthrough Network Load BalancersTCP or UDP These load balancers also support other IP protocol traffic such as ESP, GRE, ICMP, and ICMPv6.
Proxy Network Load BalancersTCP with optional SSL offload

What is the difference between network and application? ›

Network layer protocols are responsible for the delivery of data packets from one device to another, while application layer protocols are responsible for enabling specific types of communication between applications.

What are the three types of load balancers? ›

You can use ELB to set up four different types of software load balancers.
  • An Application Load Balancer routes traffic for HTTP-based requests.
  • A Network Load Balancer routes traffic based on IP addresses. ...
  • A Gateway Load Balancer routes traffic to third-party virtual appliances.

Is load balancer a network device? ›

Load balancing distributes network traffic dynamically across a network of resources that support an application. A load balancer is the device or service that sits between the user and the server group and acts as an invisible facilitator, ensuring that all resource servers are used equally.

When should you use a Network Load Balancer? ›

Among the best use cases for Network Load Balancer include:
  1. A demand for seamless support of high-volume or spiky inbound TCP requests.
  2. A need to support an elastic or static IP address.
  3. To support more than one port on an EC2 instance while using container services.

Top Articles
Latest Posts
Article information

Author: Reed Wilderman

Last Updated:

Views: 5289

Rating: 4.1 / 5 (72 voted)

Reviews: 95% of readers found this page helpful

Author information

Name: Reed Wilderman

Birthday: 1992-06-14

Address: 998 Estell Village, Lake Oscarberg, SD 48713-6877

Phone: +21813267449721

Job: Technology Engineer

Hobby: Swimming, Do it yourself, Beekeeping, Lapidary, Cosplaying, Hiking, Graffiti

Introduction: My name is Reed Wilderman, I am a faithful, bright, lucky, adventurous, lively, rich, vast person who loves writing and wants to share my knowledge and understanding with you.