Rumah  >  Artikel  >  pembangunan bahagian belakang  >  Kegagalan dan mekanisme pemulihan dalam penyelesaian pengimbangan beban Nginx

Kegagalan dan mekanisme pemulihan dalam penyelesaian pengimbangan beban Nginx

王林
王林asal
2023-10-15 11:14:141290semak imbas

Kegagalan dan mekanisme pemulihan dalam penyelesaian pengimbangan beban Nginx

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.

  1. Failover berasaskan pemeriksaan kesihatan
    Modul huluan Nginx menyediakan mekanisme failover berdasarkan pemeriksaan kesihatan yang aktif. Dengan kerap menghantar permintaan pemeriksaan kesihatan ke pelayan bahagian belakang, ketersediaan nod boleh dinilai dan pengimbangan beban boleh dilakukan berdasarkan hasil semakan. Apabila nod gagal, Nginx akan memajukan permintaan secara automatik ke nod normal lain untuk mencapai failover.

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.

  1. Failover berdasarkan pengesanan aktif
    Modul strim Nginx menyediakan mekanisme failover berdasarkan pengesanan aktif. Dengan menghantar permintaan probe secara berkala ke pelayan backend, ketersediaan nod boleh dikesan dan pengimbangan beban boleh dilakukan berdasarkan hasil siasatan. Apabila nod gagal, Nginx akan memajukan permintaan secara automatik ke nod normal lain untuk mencapai failover.

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.

  1. Pemulihan kegagalan berdasarkan pemeriksaan kesihatan
    Modul huluan Nginx juga menyediakan mekanisme pemulihan kegagalan berdasarkan pemeriksaan kesihatan yang aktif. Selepas ketersediaan nod dipulihkan, Nginx akan mengagihkan semula permintaan secara automatik ke nod.

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.

  1. Pemulihan kegagalan berasaskan berat
    Modul huluan Nginx juga menyediakan mekanisme pemulihan kegagalan berasaskan berat. Dengan menetapkan nilai berat yang berbeza untuk nod, nisbah pengagihan beban boleh dikawal. Apabila ketersediaan nod dipulihkan, nilai berat nod boleh dilaraskan untuk mengembalikannya secara beransur-ansur kepada status beban normal.

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!

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