Rumah >pembangunan bahagian belakang >tutorial php >Bagaimana untuk mengoptimumkan prestasi dan kestabilan pengimbangan beban Nginx

Bagaimana untuk mengoptimumkan prestasi dan kestabilan pengimbangan beban Nginx

PHPz
PHPzasal
2023-10-15 14:09:401420semak imbas

Bagaimana untuk mengoptimumkan prestasi dan kestabilan pengimbangan beban Nginx

Cara mengoptimumkan prestasi dan kestabilan pengimbangan beban Nginx

Abstrak: Sebagai pelayan web berprestasi tinggi sumber terbuka dan pelayan proksi terbalik, fungsi pengimbangan beban Nginx boleh mengedarkan permintaan untuk meningkatkan prestasi sistem dan jantina kebolehpercayaan dengan berkesan. Artikel ini akan memperkenalkan cara mengoptimumkan prestasi dan kestabilan pengimbangan beban Nginx dan memberikan contoh kod khusus.

  1. Gunakan modul huluan untuk mengkonfigurasi pelayan hujung belakang

Nginx melaksanakan pengimbangan beban melalui modul huluan Berbilang pelayan bahagian belakang boleh dikonfigurasikan untuk mengedarkan permintaan mengikut algoritma pengimbangan beban yang berbeza. Berikut ialah contoh konfigurasi huluan:

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

    server {
        location / {
            proxy_pass http://backend;
        }
    }
}

Dalam konfigurasi di atas, Nginx akan memajukan permintaan kepada salah satu pelayan dalam backend1.example.com, backend2.example.com dan backend3.example.com.

  1. Pilih algoritma pengimbangan beban yang sesuai

Nginx menyokong pelbagai algoritma pengimbangan beban, termasuk pengundian, pencincangan IP, sambungan paling sedikit, dsb. Memilih algoritma pengimbangan beban yang sesuai berdasarkan situasi sebenar boleh mengoptimumkan prestasi dan kestabilan. Contohnya, jika konfigurasi dan prestasi pelayan bahagian belakang adalah serupa, anda boleh menggunakan algoritma tinjauan pendapat jika anda perlu memastikan permintaan pengguna dalam sesi yang sama sentiasa dimajukan ke pelayan yang sama, anda boleh menggunakan algoritma cincang IP. Di bawah ialah contoh konfigurasi algoritma pengimbangan beban:

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

    server {
        location / {
            proxy_pass http://backend;
        }
    }
}

Dalam konfigurasi di atas, Nginx akan menggunakan algoritma cincang IP untuk memilih pelayan bahagian belakang berdasarkan alamat IP sumber permintaan.

  1. Konfigurasikan pemeriksaan kesihatan dan failover

Untuk meningkatkan kebolehpercayaan pengimbangan beban, Nginx boleh dikonfigurasikan untuk pemeriksaan kesihatan dan failover. Pemeriksaan kesihatan boleh menyemak status pelayan bahagian belakang secara berkala dan mengalih keluar pelayan yang gagal daripada kumpulan pengimbangan beban. Failover boleh disediakan untuk mendayakan semula pelayan yang gagal selepas tempoh masa, sekiranya kegagalan itu bersifat sementara.

Berikut ialah contoh pemeriksaan kesihatan dan konfigurasi failover:

http {
    upstream backend {
        server backend1.example.com max_fails=3 fail_timeout=30s;
        server backend2.example.com max_fails=3 fail_timeout=30s;
        server backend3.example.com max_fails=3 fail_timeout=30s;
        health_check;
    }

    server {
        location / {
            proxy_pass http://backend;
        }
    }
}

Dalam konfigurasi di atas, Nginx akan melakukan pemeriksaan kesihatan pada pelayan bahagian belakang dan mengalih keluar sementara pelayan yang gagal lebih daripada 3 kali daripada kumpulan pengimbangan beban, Dayakan semula selepas 30 saat.

  1. Konfigurasi caching dan mampatan

Mengkonfigurasi cache boleh mengurangkan beban pada pelayan bahagian belakang dan meningkatkan kelajuan tindak balas dengan menyimpan kandungan yang agak stabil. Mengkonfigurasi pemampatan boleh memampatkan data yang dihantar, mengurangkan penggunaan lebar jalur rangkaian dan meningkatkan prestasi. Berikut ialah contoh konfigurasi cache dan mampatan:

http {
    proxy_cache_path /path/to/cache levels=1:2 keys_zone=my_cache:10m inactive=1d max_size=1g;
    gzip on;
    gzip_types text/plain text/css application/json;

    server {
        location / {
            proxy_pass http://backend;
            proxy_cache my_cache;
            proxy_cache_valid 200 302 10m;
            proxy_cache_valid 404 1m;
            gzip_proxied any;
        }
    }
}

Dalam konfigurasi di atas, Nginx akan menyimpan kandungan cache dalam fail cache di bawah laluan yang ditentukan dan memampatkan data yang dipindahkan melalui gzip.

Kesimpulan: Dengan mengkonfigurasi fungsi pengimbangan beban Nginx dengan betul, prestasi dan kestabilan sistem boleh dioptimumkan. Memilih algoritma pengimbangan beban yang sesuai berdasarkan situasi sebenar, mengkonfigurasi pemeriksaan kesihatan dan failover, dan menggunakan strategi seperti caching dan mampatan boleh meningkatkan lagi prestasi dan kebolehpercayaan sistem. Di atas adalah beberapa contoh kod khusus, yang boleh diubah suai dan dikembangkan mengikut keperluan sebenar.

Atas ialah kandungan terperinci Bagaimana untuk mengoptimumkan prestasi dan kestabilan 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