search
HomeSystem TutorialLINUXHAProxy on Ubuntu: Load Balancing and Failover for Resilient Infrastructure

HAProxy on Ubuntu: Load Balancing and Failover for Resilient Infrastructure

Introduction

In today's fast-paced digital environment, ensuring application availability and performance is critical. Modern infrastructure requires powerful solutions to efficiently allocate traffic, maintaining service availability even in case of server failure. HAProxyAs the actual standard for high-performance load balancing and failover, it came into being.

This article explores the synergy between HAProxy and Ubuntu, one of the most popular Linux distributions. From installation to advanced configuration, we'll dive into how HAProxy can transform your infrastructure with load balancing and failover capabilities.

Detailed explanation of load balancing

Load balancing is the process of allocating incoming network traffic to multiple servers. By balancing the load, it ensures that no single server is overwhelmed, thereby improving performance, reliability, and fault tolerance.

Main advantages:

  • Scalability: Training growing traffic by adding more servers.
  • Reliability: Easy the impact of server failure by routing traffic to a normal server.
  • Performance: Reduce latency by evenly distributing workloads.

Load balancing type:

  • Layer 4 (transport layer): Distribute traffic according to IP and port information.
  • Layer 7 (application layer): Make routing decisions based on application-level data (such as HTTP headers).

Failover Concept

Failover ensures continuity by automatically redirecting traffic to backup resources in the event of a major resource failure. It is the cornerstone of the High Availability (HA) setup.

With HAProxy, failover is seamless:

  • If the backend server is not available, HAProxy will detect it through a health check.
  • Traffic will be rerouted to other available servers, thus maintaining uninterrupted service.

Set HAProxy on Ubuntu

Let's start by installing and configuring HAProxy on Ubuntu.

Prerequisite:

  • A Ubuntu server (recommended to use 20.04 or higher).
  • Multiple backend servers for testing load balancing.
  • Basic Linux command line skills.

Step 1: Install HAProxy

  1. Update your system: sudo apt update && sudo apt upgrade -y
  2. Installing HAProxy: sudo apt install haproxy -y
  3. Verify installation: haproxy -v

Step 2: Configure HAProxy Edit /etc/haproxy/haproxy.cfgConfiguration file:

<code>global
    log /dev/log local0
    log /dev/log local1 notice
    maxconn 2048
    daemon
defaults
    log global
    option httplog
    option dontlognull
    timeout connect 5000ms
    timeout client 50000ms
    timeout server 50000ms
frontend http_front
    bind *:80
    default_backend http_back
backend http_back
    balance roundrobin
    server server1 192.168.1.101:80 check
    server server2 192.168.1.102:80 check</code>
  1. Restart HAProxy to apply changes: sudo systemctl restart haproxy
  2. Test by accessing the server's IP address. HAProxy will allocate requests between backends.

Advanced Configuration

Load balancing algorithm:

  • Poll: Sequentially allocate requests.
  • Number of connections: Routed to the server with the least active connections.
  • Source: Make sure the client is always routed to the same server.

Update the balance directive in the backend accordingly.

Health Check: Health Check ensures that traffic is sent to normal servers only. check The instruction performs regular health checks.

SSL Termination: To protect traffic, configure HAProxy to handle SSL Termination.

  1. Get the SSL certificate.
  2. Update configuration to use HTTPS: frontend https_front bind *:443 ssl crt /etc/haproxy/certs/example.pem default_backend http_back

Access Control List (ACL): Filter traffic using ACL:

<code>frontend http_front
    acl is_api path_beg /api
    use_backend api_back if is_api</code>

Enable high availability

VRRP with Keepalived: To enable failover, integrate Keepalived with HAProxy.

  1. Installing Keepalived: sudo apt install keepalived -y
  2. Configuration Keepalived (/etc/keepalived/keepalived.conf):
<code>vrrp_instance VI_1 {
    state MASTER
    interface eth0
    virtual_router_id 51
    priority 100
    advert_int 1
    authentication {
        auth_type PASS
        auth_pass mypassword
    }
    virtual_ipaddress {
        192.168.1.100
    }
}</code>
  1. Restart Keepalived: sudo systemctl restart keepalived

Keepalived ensures that the secondary server takes over seamlessly when the primary server fails.

Monitoring and Performance Tuning

HAProxy Statistics Panel: Enable the panel for real-time monitoring:

<code>listen stats
    bind *:8404
    stats enable
    stats uri /stats
    stats auth admin:password</code>

Access it in http://<server-ip>:8404/stats</server-ip>.

Optimization skills:

  • Adjust the maxconn and timeout settings.
  • Use gzip compression for HTTP traffic.
  • Monitor exceptions in the log.

User cases and actual scenarios

  • Microservices: Assign API requests to multiple services.
  • Web Application: Handle traffic spikes by extending backend servers.
  • Database load balancing: Optimize read and write operations.

Troubleshooting of FAQs

Connection problem:

  • Check firewall rules.
  • Verify server health check.

Performance bottleneck:

  • Add the file descriptor's ulimit.
  • Optimize backend server configuration.

Maintenance:

  • Always backup configuration.
  • Apply updates during low traffic.

Conclusion

By combining HAProxy and Ubuntu, you get a powerful combination to manage traffic and ensure uptime. With the above steps, you can build a resilient infrastructure that can handle high loads and server failures.

Start trying HAProxy now and unlock the full potential of Ubuntu system capabilities.

The above is the detailed content of HAProxy on Ubuntu: Load Balancing and Failover for Resilient Infrastructure. For more information, please follow other related articles on the PHP Chinese website!

Statement
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Does the internet run on Linux?Does the internet run on Linux?Apr 14, 2025 am 12:03 AM

The Internet does not rely on a single operating system, but Linux plays an important role in it. Linux is widely used in servers and network devices and is popular for its stability, security and scalability.

What are Linux operations?What are Linux operations?Apr 13, 2025 am 12:20 AM

The core of the Linux operating system is its command line interface, which can perform various operations through the command line. 1. File and directory operations use ls, cd, mkdir, rm and other commands to manage files and directories. 2. User and permission management ensures system security and resource allocation through useradd, passwd, chmod and other commands. 3. Process management uses ps, kill and other commands to monitor and control system processes. 4. Network operations include ping, ifconfig, ssh and other commands to configure and manage network connections. 5. System monitoring and maintenance use commands such as top, df, du to understand the system's operating status and resource usage.

Boost Productivity with Custom Command Shortcuts Using Linux AliasesBoost Productivity with Custom Command Shortcuts Using Linux AliasesApr 12, 2025 am 11:43 AM

Introduction Linux is a powerful operating system favored by developers, system administrators, and power users due to its flexibility and efficiency. However, frequently using long and complex commands can be tedious and er

What is Linux actually good for?What is Linux actually good for?Apr 12, 2025 am 12:20 AM

Linux is suitable for servers, development environments, and embedded systems. 1. As a server operating system, Linux is stable and efficient, and is often used to deploy high-concurrency applications. 2. As a development environment, Linux provides efficient command line tools and package management systems to improve development efficiency. 3. In embedded systems, Linux is lightweight and customizable, suitable for environments with limited resources.

Essential Tools and Frameworks for Mastering Ethical Hacking on LinuxEssential Tools and Frameworks for Mastering Ethical Hacking on LinuxApr 11, 2025 am 09:11 AM

Introduction: Securing the Digital Frontier with Linux-Based Ethical Hacking In our increasingly interconnected world, cybersecurity is paramount. Ethical hacking and penetration testing are vital for proactively identifying and mitigating vulnerabi

How to learn Linux basics?How to learn Linux basics?Apr 10, 2025 am 09:32 AM

The methods for basic Linux learning from scratch include: 1. Understand the file system and command line interface, 2. Master basic commands such as ls, cd, mkdir, 3. Learn file operations, such as creating and editing files, 4. Explore advanced usage such as pipelines and grep commands, 5. Master debugging skills and performance optimization, 6. Continuously improve skills through practice and exploration.

What is the most use of Linux?What is the most use of Linux?Apr 09, 2025 am 12:02 AM

Linux is widely used in servers, embedded systems and desktop environments. 1) In the server field, Linux has become an ideal choice for hosting websites, databases and applications due to its stability and security. 2) In embedded systems, Linux is popular for its high customization and efficiency. 3) In the desktop environment, Linux provides a variety of desktop environments to meet the needs of different users.

What are the disadvantages of Linux?What are the disadvantages of Linux?Apr 08, 2025 am 12:01 AM

The disadvantages of Linux include user experience, software compatibility, hardware support, and learning curve. 1. The user experience is not as friendly as Windows or macOS, and it relies on the command line interface. 2. The software compatibility is not as good as other systems and lacks native versions of many commercial software. 3. Hardware support is not as comprehensive as Windows, and drivers may be compiled manually. 4. The learning curve is steep, and mastering command line operations requires time and patience.

See all articles

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

AI Hentai Generator

AI Hentai Generator

Generate AI Hentai for free.

Hot Article

R.E.P.O. Energy Crystals Explained and What They Do (Yellow Crystal)
4 weeks agoBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Best Graphic Settings
4 weeks agoBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. How to Fix Audio if You Can't Hear Anyone
4 weeks agoBy尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: How To Unlock Everything In MyRise
1 months agoBy尊渡假赌尊渡假赌尊渡假赌

Hot Tools

VSCode Windows 64-bit Download

VSCode Windows 64-bit Download

A free and powerful IDE editor launched by Microsoft

EditPlus Chinese cracked version

EditPlus Chinese cracked version

Small size, syntax highlighting, does not support code prompt function

SublimeText3 Linux new version

SublimeText3 Linux new version

SublimeText3 Linux latest version

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

DVWA

DVWA

Damn Vulnerable Web App (DVWA) is a PHP/MySQL web application that is very vulnerable. Its main goals are to be an aid for security professionals to test their skills and tools in a legal environment, to help web developers better understand the process of securing web applications, and to help teachers/students teach/learn in a classroom environment Web application security. The goal of DVWA is to practice some of the most common web vulnerabilities through a simple and straightforward interface, with varying degrees of difficulty. Please note that this software