Failover dan mekanisme pemulihan dalam penyelesaian pengimbangan beban Nginx
Pengenalan:
Untuk laman web muatan tinggi, menggunakan pengimbangan beban adalah salah satu cara penting untuk memastikan ketersediaan tinggi tapak web dan meningkatkan prestasi. Sebagai pelayan web sumber terbuka yang berkuasa, fungsi pengimbangan beban Nginx telah digunakan secara meluas. Dalam pengimbangan beban, cara melaksanakan mekanisme failover dan pemulihan merupakan isu penting yang perlu dipertimbangkan. Artikel ini akan memperkenalkan mekanisme failover dan pemulihan dalam pengimbangan beban Nginx dan memberikan contoh kod khusus.
1. Mekanisme Failover
Failover merujuk kepada keupayaan sistem untuk memindahkan beban dengan lancar ke nod normal lain apabila satu atau beberapa nod gagal. Nginx menyediakan pelbagai pilihan konfigurasi mekanisme failover Berikut adalah beberapa kaedah yang biasa digunakan.
Berikut ialah contoh konfigurasi pengimbangan beban berasaskan pemeriksaan kesihatan:
upstream backend { server backend1.example.com:80; server backend2.example.com:80; check interval=3000 rise=2 fall=3 timeout=1000; } server { listen 80; server_name example.com; location / { proxy_pass http://backend; } }
Dalam konfigurasi di atas, permintaan pemeriksaan kesihatan dihantar ke pelayan bahagian belakang setiap 3 saat. Apabila terdapat dua tindak balas normal berturut-turut, nod dianggap kembali normal apabila terdapat tiga tindak balas abnormal berturut-turut, nod dianggap rosak. Nginx akan melakukan pengimbangan beban berdasarkan ketersediaan nod dan secara automatik bertukar kepada nod biasa.
Berikut ialah contoh konfigurasi pengimbangan beban berdasarkan pengesanan aktif:
stream { upstream backend { server backend1.example.com:80; server backend2.example.com:80; check interval=3000 rise=2 fall=3 timeout=1000; } server { listen 80; proxy_pass backend; } }
Dalam konfigurasi di atas, permintaan pengesanan dihantar ke pelayan bahagian belakang setiap 3 saat. Apabila terdapat dua tindak balas normal berturut-turut, nod dianggap kembali normal apabila terdapat tiga tindak balas abnormal berturut-turut, nod dianggap rosak. Nginx akan melakukan pengimbangan beban berdasarkan ketersediaan nod dan secara automatik bertukar kepada nod biasa.
2. Mekanisme pemulihan kerosakan
Pemulihan kegagalan merujuk kepada keupayaan sistem untuk mengagihkan semula beban secara automatik ke nod selepas kegagalan nod dibaiki. Nginx menyediakan pelbagai pilihan konfigurasi untuk mekanisme pemulihan kegagalan Berikut adalah beberapa kaedah yang biasa digunakan.
Berikut ialah contoh konfigurasi pemulihan kegagalan berasaskan pemeriksaan kesihatan:
upstream backend { server backend1.example.com:80; server backend2.example.com:80; check interval=3000 rise=2 fall=3 timeout=1000; } server { listen 80; server_name example.com; location / { proxy_pass http://backend; } }
Dalam konfigurasi di atas, apabila ketersediaan nod dipulihkan, Nginx akan mengagihkan semula permintaan ke nod secara automatik.
Berikut ialah contoh konfigurasi pemulihan kegagalan berdasarkan berat:
upstream backend { server backend1.example.com:80 weight=5; server backend2.example.com:80 weight=1; } server { listen 80; server_name example.com; location / { proxy_pass http://backend; } }
Dalam konfigurasi di atas, berat bahagian belakang pelayan belakang1 ialah 5 dan berat hujung belakang pelayan belakang2 ialah 1. Apabila ketersediaan backend1 dipulihkan, nilai beratnya boleh dilaraskan supaya ia kembali secara beransur-ansur kepada 5 untuk mencapai pemulihan kegagalan.
Kesimpulan:
Artikel ini memperkenalkan mekanisme failover dan pemulihan dalam penyelesaian pengimbangan beban Nginx dan memberikan contoh kod khusus. Dengan mengkonfigurasi failover dan mekanisme pemulihan dengan betul, ketersediaan dan prestasi sistem boleh dipertingkatkan. Dalam aplikasi sebenar, kaedah konfigurasi yang sesuai boleh dipilih mengikut keperluan dan senario khusus untuk mencapai kesan pengimbangan beban yang optimum.
Atas ialah kandungan terperinci Kegagalan dan mekanisme pemulihan dalam penyelesaian pengimbangan beban Nginx. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!