Rumah >pembangunan bahagian belakang >tutorial php >Prinsip dan amalan pengimbangan beban Nginx

Prinsip dan amalan pengimbangan beban Nginx

WBOY
WBOYasal
2023-10-15 15:00:121408semak imbas

Prinsip dan amalan pengimbangan beban Nginx

Prinsip dan Amalan Pengimbangan Beban Nginx

Pengenalan:
Pengimbangan beban ialah konsep penting yang memainkan peranan dalam rangkaian moden peranan penting dalam memastikan laman web atau aplikasi boleh mengendalikan sejumlah besar permintaan serentak dan menyediakan ketersediaan yang tinggi. Nginx ialah perisian sumber terbuka popular yang terkenal dengan keupayaan pengimbangan beban yang sangat baik. Dalam artikel ini, kami akan meneroka konsep, prinsip dan cara melaksanakan pengimbangan beban Nginx.

1. Prinsip pengimbangan beban

  1. Apakah pengimbangan beban?
    Pengimbangan beban merujuk kepada pengagihan permintaan rangkaian kepada berbilang pelayan untuk mengimbangi beban pelayan dan meningkatkan kebolehskalaan dan prestasi sistem. Apabila pelayan terlebih muatan, pengimbang beban memajukan permintaan kepada pelayan lain untuk mengelakkan satu titik kegagalan dan ketiadaan perkhidmatan.
  2. Cara pengimbangan beban berfungsi
    Pengimbang beban biasanya menggunakan strategi yang berbeza untuk memutuskan cara mengagihkan permintaan. Berikut ialah beberapa strategi pengimbangan beban biasa:
  3. Strategi pengundian: Edarkan permintaan kepada setiap pelayan secara bergilir-gilir, mengulangi kitaran.
  4. Strategi undian berwajaran: Berikan pemberat kepada setiap pelayan dan peruntukkan permintaan mengikut nisbah berat.
  5. IP Hash Strategy: Edarkan permintaan kepada pelayan tertentu berdasarkan alamat IP pelanggan.
  6. Strategi sambungan paling sedikit: Edarkan permintaan kepada pelayan dengan bilangan sambungan semasa terkecil.
  7. Faedah pengimbang beban
    Menggunakan pengimbang beban mempunyai faedah berikut:
  8. Meningkatkan ketersediaan sistem: Apabila pelayan gagal, pengimbang beban boleh mengubah hala permintaan Dimajukan ke pelayan lain yang biasa beroperasi untuk memastikan kesinambungan sistem.
  9. Tingkatkan prestasi: Dengan mengedarkan permintaan kepada berbilang pelayan, anda boleh mengurangkan beban pada satu pelayan dan meningkatkan kelajuan tindak balas dan daya pemprosesan sistem.
  10. Skalabiliti: Kapasiti sistem boleh dikembangkan dengan mudah dengan menambahkan lebih banyak pelayan.

2. Amalan pengimbangan beban Nginx
Nginx ialah pelayan web yang berkuasa dan pelayan proksi terbalik. Ia juga boleh digunakan sebagai pengimbang beban. Berikut adalah langkah praktikal untuk mencapai pengimbangan beban melalui Nginx:

  1. Pasang Nginx
    Pertama, pastikan Nginx dipasang. Anda boleh menyemak sama ada Nginx telah dipasang dengan menjalankan arahan berikut dalam terminal:

    nginx -v

    Jika sudah dipasang, maklumat versi Nginx akan dipaparkan. Jika ia tidak dipasang, anda boleh memasangnya melalui pengurus pakej anda.

  2. Konfigurasikan strategi pengimbangan beban
    Buka fail konfigurasi Nginx, biasanya terletak di /etc/nginx/nginx.conf atau /usr/local/nginx/conf/nginx.conf. Cari blok http dan tambahkan kod berikut: /etc/nginx/nginx.conf/usr/local/nginx/conf/nginx.conf。找到http块并添加以下代码:

    http {
     upstream backend {
         server backend1.example.com;
         server backend2.example.com;
     }
     ...
    }

    在以上示例中,我们创建了一个名为backend

    http {
     upstream backend {
         server backend1.example.com;
         server backend2.example.com;
         server backend3.example.com;
         ...
         server backendn.example.com;
     }
     ...
     server {
         ...
         location / {
             proxy_pass http://backend;
         }
     }
    }

    Dalam contoh di atas, kami mencipta blok hulu bernama backend dan menyatakan alamat dua pelayan bahagian belakang. Anda boleh menambah lebih banyak pelayan bahagian belakang berdasarkan keperluan anda.

  3. Konfigurasikan strategi pengimbangan beban
  4. Dalam fail konfigurasi, kita boleh menggunakan strategi pengimbangan beban yang berbeza. Berikut ialah beberapa contoh konfigurasi dasar pengimbangan beban biasa:
  5. Strategi pengundian:

    http {
     upstream backend {
         server backend1.example.com weight=3;
         server backend2.example.com weight=2;
         server backend3.example.com weight=1;
     }
     ...
    }

    Dalam contoh di atas, permintaan akan diedarkan kepada setiap jawatan secara bergilir-gilir pelayan akhir.
  6. Strategi undian berwajaran:

    http {
     upstream backend {
         ip_hash;
         server backend1.example.com;
         server backend2.example.com;
     }
     ...
    }

    Dalam contoh di atas, kami memberikan pemberat yang berbeza kepada setiap pelayan bahagian belakang, semakin tinggi berat semakin tinggi nombor, lebih banyak permintaan diterima.
  7. IP Hash Strategy:

    http {
     upstream backend {
         least_conn;
         server backend1.example.com;
         server backend2.example.com;
     }
     ...
    }

    Dalam contoh di atas, Nginx akan menghantar permintaan ke backend yang ditentukan berdasarkan pelayan alamat IP klien .
  8. Strategi sambungan paling sedikit:

    nginx -s reload

    Dalam contoh di atas, Nginx akan menghantar permintaan kepada pelayan dengan bilangan sambungan semasa yang paling sedikit.

  9. Mulakan Semula Nginx

    Selepas melengkapkan konfigurasi, simpan fail dan mulakan semula Nginx untuk perubahan berkuat kuasa:

    rreee#🎜🎜 , anda mempunyai Fungsi pengimbangan beban Nginx telah berjaya dikonfigurasikan.

Kesimpulan:
Pengimbangan beban ialah teknologi yang amat diperlukan dalam rangkaian moden, yang boleh memastikan ketersediaan dan kebolehskalaan tinggi tapak web atau aplikasi . Dengan menggunakan Nginx sebagai pengimbang beban, anda boleh memilih strategi pengimbangan beban yang berbeza mengikut keperluan sebenar dan meningkatkan prestasi dan ketersediaan sistem dengan menambahkan lebih banyak pelayan. Saya harap artikel ini dapat membantu anda memahami konsep, prinsip dan kaedah praktikal pengimbangan beban Nginx, dan memainkan peranan dalam aplikasi praktikal.

Atas ialah kandungan terperinci Prinsip dan amalan 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