search
HomeBackend DevelopmentPHP TutorialApache Virtual Host: Load Balancer

Apache Virtual Host: Load Balancer

Load balancing is an excellent strategy for distributing requests across multiple backend servers, improving system scalability and availability. Apache can be configured as a load balancer using the mod_proxy_balancer module.

Here is a complete guide to implementing load balancing in Apache:

Enable the Required Modules

First, enable the required modules in Apache:

sudo a2enmod proxy
sudo a2enmod proxy_http
sudo a2enmod proxy_balancer
sudo a2enmod lbmethod_byrequests

Restart Apache to load the modules:

sudo systemctl restart apache2

Configure Virtual Host with Load Balancing

Now, edit your Virtual Host's configuration file to add the load balancing directives.

Open the configuration file:

sudo your_editor /etc/apache2/sites-available/php.conf

Add the following block of code to configure load balancing across multiple backend servers:

<virtualhost>
    ServerAdmin webmaster@localhost
    ServerName php.info

    # Load balancer configuration
    <proxy>
        BalancerMember http://localhost:8080
        BalancerMember http://localhost:8081
        BalancerMember http://localhost:8082
        ProxySet lbmethod=byrequests
    </proxy>

    ProxyPreserveHost On
    ProxyPass / balancer://meucluster/
    ProxyPassReverse / balancer://meucluster/

    <directory></directory>
        AllowOverride All
        Require all granted
    

    ErrorLog ${APACHE_LOG_DIR}/php_error_http.log
    CustomLog ${APACHE_LOG_DIR}/php_access_http.log combined
</virtualhost>

Explanation of the above elements:

  • BalancerMember: Defines the backend servers. In this case, we are configuring three servers listening on ports 8080, 8081, and 8082. You can replace these values ​​with your actual servers.
  • lbmethod=byrequests: Defines the balancing method. byrequests distributes requests equally among the servers. Other methods include:
    • bytraffic: distributes based on the amount of traffic.
    • bybusyness: distributes based on the number of active connections.
    • heartbeat: uses an advanced health monitoring approach.

Add Backend Servers

In the above example, I'm assuming you have three backend services running on localhost on ports 8080, 8081, and 8082. Make sure you have these services running.

Otherwise, you can configure backend servers with the correct ports or use Docker containers to simulate multiple services.

Enable SSL Module for HTTPS

If you want to load balance over HTTPS, also add the SSL Virtual Host (/etc/apache2/sites-available/php-le-ssl.conf) to load balance across HTTPS backend servers:

<ifmodule mod_ssl.c>
    <virtualhost>
        ServerAdmin webmaster@localhost
        ServerName php.info
        DocumentRoot /var/www/meu_projeto

        # Configuração do Balanceador de Carga
        <proxy>
            BalancerMember http://localhost:8080
            BalancerMember http://localhost:8081
            BalancerMember http://localhost:8082
            ProxySet lbmethod=byrequests
        </proxy>

        ProxyPreserveHost On
        ProxyPass / balancer://meucluster/
        ProxyPassReverse / balancer://meucluster/

        SSLEngine on
        SSLCertificateFile /etc/letsencrypt/live/php.info/fullchain.pem
        SSLCertificateKeyFile /etc/letsencrypt/live/php.info/privkey.pem
        Include /etc/letsencrypt/options-ssl-apache.conf

        ErrorLog ${APACHE_LOG_DIR}/php_error_https.log
        CustomLog ${APACHE_LOG_DIR}/php_access_https.log combined
    </virtualhost>
</ifmodule>

Advanced Configuration Options

Set Server Weights

You can set different weights for servers, meaning that some servers receive more traffic than others. Example:

BalancerMember http://localhost:8080 loadfactor=1
BalancerMember http://localhost:8081 loadfactor=2
BalancerMember http://localhost:8082 loadfactor=1

In this case, the server at localhost:8081 will receive twice as many requests as the others.

Set Failure Timeouts and Retries

You can set timeouts and retries to detect failures on backend servers:

<proxy>
BalancerMember http://localhost:8080 retry=5 timeout=10
BalancerMember http://localhost:8081 retry=5 timeout=10
BalancerMember http://localhost:8082 retry=5 timeout=10
ProxySet lbmethod=byrequests
</proxy>

Monitor and Manage the Load Balancer

To monitor the load balancer health and manage active/inactive members dynamically, launch the Balancer Manager interface:

<location>
SetHandler balancer-manager
Require host localhost
</location>

You can now access http://php.info/balancer-manager to view the load balancer health and adjust settings in real time.

Restart Apache

After making the configuration changes, restart Apache for the changes to take effect:

sudo systemctl restart apache2

Test Load Balancing

Now, when you access http://php.info, Apache will distribute the requests among the defined backend servers.

Implement Health Checks (Optional)

You can configure Apache to check the health of backend servers and automatically remove them from the pool if they are down. To do this, you can use the mod_proxy_hcheck module.

First, enable the module:

sudo a2enmod proxy_hcheck
sudo systemctl restart apache2

Then, add the following configuration to your block:

<proxy>
    BalancerMember http://localhost:8080 hcheck=on hcmethod=HEAD
    BalancerMember http://localhost:8081 hcheck=on hcmethod=HEAD
    BalancerMember http://localhost:8082 hcheck=on hcmethod=HEAD
    ProxySet lbmethod=byrequests
</proxy>

Apache will now automatically check the backend servers and remove them from the pool if they fail.

Conclusion

With Apache configured as a load balancer, you can distribute traffic across multiple backend servers, ensuring scalability and redundancy. Using SSL and additional health checks helps keep the environment secure and robust.

The above is the detailed content of Apache Virtual Host: Load Balancer. 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
PHP Dependency Injection Container: A Quick StartPHP Dependency Injection Container: A Quick StartMay 13, 2025 am 12:11 AM

APHPDependencyInjectionContainerisatoolthatmanagesclassdependencies,enhancingcodemodularity,testability,andmaintainability.Itactsasacentralhubforcreatingandinjectingdependencies,thusreducingtightcouplingandeasingunittesting.

Dependency Injection vs. Service Locator in PHPDependency Injection vs. Service Locator in PHPMay 13, 2025 am 12:10 AM

Select DependencyInjection (DI) for large applications, ServiceLocator is suitable for small projects or prototypes. 1) DI improves the testability and modularity of the code through constructor injection. 2) ServiceLocator obtains services through center registration, which is convenient but may lead to an increase in code coupling.

PHP performance optimization strategies.PHP performance optimization strategies.May 13, 2025 am 12:06 AM

PHPapplicationscanbeoptimizedforspeedandefficiencyby:1)enablingopcacheinphp.ini,2)usingpreparedstatementswithPDOfordatabasequeries,3)replacingloopswitharray_filterandarray_mapfordataprocessing,4)configuringNginxasareverseproxy,5)implementingcachingwi

PHP Email Validation: Ensuring Emails Are Sent CorrectlyPHP Email Validation: Ensuring Emails Are Sent CorrectlyMay 13, 2025 am 12:06 AM

PHPemailvalidationinvolvesthreesteps:1)Formatvalidationusingregularexpressionstochecktheemailformat;2)DNSvalidationtoensurethedomainhasavalidMXrecord;3)SMTPvalidation,themostthoroughmethod,whichchecksifthemailboxexistsbyconnectingtotheSMTPserver.Impl

How to make PHP applications fasterHow to make PHP applications fasterMay 12, 2025 am 12:12 AM

TomakePHPapplicationsfaster,followthesesteps:1)UseOpcodeCachinglikeOPcachetostoreprecompiledscriptbytecode.2)MinimizeDatabaseQueriesbyusingquerycachingandefficientindexing.3)LeveragePHP7 Featuresforbettercodeefficiency.4)ImplementCachingStrategiessuc

PHP Performance Optimization Checklist: Improve Speed NowPHP Performance Optimization Checklist: Improve Speed NowMay 12, 2025 am 12:07 AM

ToimprovePHPapplicationspeed,followthesesteps:1)EnableopcodecachingwithAPCutoreducescriptexecutiontime.2)ImplementdatabasequerycachingusingPDOtominimizedatabasehits.3)UseHTTP/2tomultiplexrequestsandreduceconnectionoverhead.4)Limitsessionusagebyclosin

PHP Dependency Injection: Improve Code TestabilityPHP Dependency Injection: Improve Code TestabilityMay 12, 2025 am 12:03 AM

Dependency injection (DI) significantly improves the testability of PHP code by explicitly transitive dependencies. 1) DI decoupling classes and specific implementations make testing and maintenance more flexible. 2) Among the three types, the constructor injects explicit expression dependencies to keep the state consistent. 3) Use DI containers to manage complex dependencies to improve code quality and development efficiency.

PHP Performance Optimization: Database Query OptimizationPHP Performance Optimization: Database Query OptimizationMay 12, 2025 am 12:02 AM

DatabasequeryoptimizationinPHPinvolvesseveralstrategiestoenhanceperformance.1)Selectonlynecessarycolumnstoreducedatatransfer.2)Useindexingtospeedupdataretrieval.3)Implementquerycachingtostoreresultsoffrequentqueries.4)Utilizepreparedstatementsforeffi

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

Video Face Swap

Video Face Swap

Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

WebStorm Mac version

WebStorm Mac version

Useful JavaScript development tools

PhpStorm Mac version

PhpStorm Mac version

The latest (2018.2.1) professional PHP integrated development tool

mPDF

mPDF

mPDF is a PHP library that can generate PDF files from UTF-8 encoded HTML. The original author, Ian Back, wrote mPDF to output PDF files "on the fly" from his website and handle different languages. It is slower than original scripts like HTML2FPDF and produces larger files when using Unicode fonts, but supports CSS styles etc. and has a lot of enhancements. Supports almost all languages, including RTL (Arabic and Hebrew) and CJK (Chinese, Japanese and Korean). Supports nested block-level elements (such as P, DIV),