Rumah >pembangunan bahagian belakang >tutorial php >Hos Maya Apache: Pengimbang Beban

Hos Maya Apache: Pengimbang Beban

Susan Sarandon
Susan Sarandonasal
2024-10-11 10:10:30758semak imbas

Apache Virtual Host: Load Balancer

Pengimbangan beban ialah strategi yang sangat baik untuk mengagihkan permintaan merentas berbilang pelayan bahagian belakang, meningkatkan kebolehskalaan dan ketersediaan sistem. Apache boleh dikonfigurasikan sebagai pengimbang beban menggunakan modul mod_proxy_balancer.

Berikut ialah panduan lengkap untuk melaksanakan imbangan beban dalam Apache:

Dayakan Modul yang Diperlukan

Pertama, dayakan modul yang diperlukan dalam Apache:

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

Mulakan semula Apache untuk memuatkan modul:

sudo systemctl restart apache2

Konfigurasikan Hos Maya dengan Pengimbangan Beban

Sekarang, edit fail konfigurasi Hos Maya anda untuk menambah arahan pengimbangan beban.

Buka fail konfigurasi:

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

Tambah blok kod berikut untuk mengkonfigurasi imbangan beban merentas berbilang pelayan bahagian belakang:

<VirtualHost *:80>
    ServerAdmin webmaster@localhost
    ServerName php.info

    # Load balancer configuration
    <Proxy "balancer://meucluster">
        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 /var/www/html/php/>
        AllowOverride All
        Require all granted
    </Directory>

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

Penjelasan elemen di atas:

  • BalancerMember: Mentakrifkan pelayan bahagian belakang. Dalam kes ini, kami sedang mengkonfigurasi tiga pelayan mendengar pada port 8080, 8081 dan 8082. Anda boleh menggantikan nilai ini dengan pelayan sebenar anda.
  • lbmethod=byrequests: Mentakrifkan kaedah pengimbangan. byrequests mengedarkan permintaan secara sama rata antara pelayan. Kaedah lain termasuk:
    • bytraffic: mengedarkan berdasarkan jumlah trafik.
    • bybusyness: mengedarkan berdasarkan bilangan sambungan aktif.
    • degupan jantung: menggunakan pendekatan pemantauan kesihatan lanjutan.

Tambah Pelayan Bahagian Belakang

Dalam contoh di atas, saya mengandaikan anda mempunyai tiga perkhidmatan bahagian belakang yang dijalankan pada localhost pada port 8080, 8081 dan 8082. Pastikan anda menjalankan perkhidmatan ini.

Jika tidak, anda boleh mengkonfigurasi pelayan bahagian belakang dengan port yang betul atau menggunakan bekas Docker untuk mensimulasikan berbilang perkhidmatan.

Dayakan Modul SSL untuk HTTPS

Jika anda ingin memuatkan baki melalui HTTPS, tambahkan juga Hos Maya SSL (/etc/apache2/sites-available/php-le-ssl.conf) untuk memuatkan baki merentas pelayan bahagian belakang HTTPS:

<IfModule mod_ssl.c>
    <VirtualHost *:443>
        ServerAdmin webmaster@localhost
        ServerName php.info
        DocumentRoot /var/www/meu_projeto

        # Configuração do Balanceador de Carga
        <Proxy "balancer://meucluster">
            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>

Pilihan Konfigurasi Lanjutan

Tetapkan Berat Pelayan

Anda boleh menetapkan pemberat yang berbeza untuk pelayan, bermakna sesetengah pelayan menerima lebih banyak trafik daripada yang lain. Contoh:

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

Dalam kes ini, pelayan di localhost:8081 akan menerima dua kali lebih banyak permintaan daripada yang lain.

Tetapkan Tamat Masa Kegagalan dan Cuba Semula

Anda boleh menetapkan tamat masa dan cuba semula untuk mengesan kegagalan pada pelayan bahagian belakang:

<Proxy "balancer://mycluster">
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>

Pantau dan Urus Pengimbang Beban

Untuk memantau kesihatan pengimbang beban dan mengurus ahli aktif/tidak aktif secara dinamik, lancarkan antara muka Pengurus Pengimbang:

<Location "/balancer-manager">
SetHandler balancer-manager
Require host localhost
</Location>

Anda kini boleh mengakses http://php.info/balancer-manager untuk melihat kesihatan pengimbang beban dan melaraskan tetapan dalam masa nyata.

Mulakan semula Apache

Selepas membuat perubahan konfigurasi, mulakan semula Apache untuk perubahan berkuat kuasa:

sudo systemctl restart apache2

Ujian Imbangan Beban

Kini, apabila anda mengakses http://php.info, Apache akan mengedarkan permintaan antara pelayan bahagian belakang yang ditentukan.

Laksanakan Pemeriksaan Kesihatan (Pilihan)

Anda boleh mengkonfigurasi Apache untuk menyemak kesihatan pelayan bahagian belakang dan mengalih keluarnya secara automatik daripada kolam jika ia tidak berfungsi. Untuk melakukan ini, anda boleh menggunakan modul mod_proxy_hcheck.

Pertama, dayakan modul:

sudo a2enmod proxy_hcheck
sudo systemctl restart apache2

Kemudian, tambahkan konfigurasi berikut pada blok:

<Proxy "balancer://meucluster">
    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 kini akan menyemak pelayan bahagian belakang secara automatik dan mengalih keluarnya daripada kumpulan jika gagal.

Kesimpulan

Dengan Apache dikonfigurasikan sebagai pengimbang beban, anda boleh mengedarkan trafik merentas berbilang pelayan bahagian belakang, memastikan kebolehskalaan dan redundansi. Menggunakan SSL dan pemeriksaan kesihatan tambahan membantu memastikan persekitaran selamat dan teguh.

Atas ialah kandungan terperinci Hos Maya Apache: Pengimbang Beban. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn