Rumah > Artikel > pembangunan bahagian belakang > Hos Maya Apache: Pengimbang Beban
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:
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
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:
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.
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>
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.
Selepas membuat perubahan konfigurasi, mulakan semula Apache untuk perubahan berkuat kuasa:
sudo systemctl restart apache2
Kini, apabila anda mengakses http://php.info, Apache akan mengedarkan permintaan antara pelayan bahagian belakang yang ditentukan.
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
<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.
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!