Cara pengehadan arus nginx berfungsi
penghadan arus nginx menggunakan algoritma baldi bocor, yang digunakan secara meluas dalam komunikasi dan rangkaian komputer bertukar paket, digunakan untuk mengendalikan kecemasan apabila lebar jalur adalah terhad. Prinsipnya hampir sama dengan baldi dengan air masuk dari atas dan bocor dari bawah jika kadar aliran masuk air lebih besar daripada kadar kebocoran air, baldi akan melimpah.
Semasa proses pemprosesan permintaan, air mewakili permintaan daripada pelanggan, dan baldi mewakili baris gilir di mana permintaan sedang menunggu untuk diproses mengikut algoritma pertama masuk dahulu (fifo) . Kebocoran bermakna permintaan meninggalkan penimbal dan diproses oleh pelayan, limpahan bermakna permintaan digugurkan dan tidak pernah disampaikan.
1 Hadkan kekerapan akses (trafik biasa)
Dalam nginx kami menggunakan modul ngx_http_limit_req_module untuk mengehadkan kekerapan akses permintaan , berdasarkan Pelaksanaan prinsip algoritma baldi bocor. Seterusnya, kami menggunakan arahan limit_req_zone dan limit_req nginx untuk mengehadkan kadar pemprosesan permintaan bagi satu IP.
Sintaks: limit_req_zone key zone rate
kunci: mentakrifkan objek pengehad semasa, binary_remote_addr ialah kunci, menunjukkan berdasarkan remote_addr ( IP End pelanggan) digunakan untuk mengehadkan arus, dan tujuan binary_ adalah untuk memampatkan penggunaan memori.
zon: Tentukan kawasan memori yang dikongsi untuk menyimpan maklumat akses myratelimit:10m mewakili kawasan memori dengan saiz 10m dan nama myratelimit. Setiap 1m boleh menyimpan maklumat capaian 16,000 alamat IP, jadi 10m boleh menyimpan maklumat capaian 160,000 alamat IP.
Parameter "kadar" digunakan untuk menetapkan kadar akses maksimum "kadar=10r/s" bermakna tidak lebih daripada 10 permintaan akan diproses sesaat. nginx sebenarnya menjejaki maklumat permintaan dengan butiran milisaat, jadi 10r/s sebenarnya adalah had: satu permintaan diproses setiap 100 milisaat. Ini bermakna jika permintaan lain tiba dalam masa 100 milisaat seterusnya selepas permintaan terakhir diproses, permintaan itu akan ditolak untuk diproses.
2. Hadkan kekerapan akses (trafik pecah)
Mengikut konfigurasi di atas, apabila trafik meningkat secara tiba-tiba, lebihan permintaan akan menjadi Penolakan, tidak dapat mengendalikan trafik pecah, jadi bagaimana untuk menangani trafik pecah? nginx menyediakan parameter pecah untuk menyelesaikan masalah trafik pecah dan digunakan bersama dengan parameter nodelay. Burst diterjemahkan sebagai pecah, pecah, menunjukkan bilangan permintaan tambahan yang boleh diproses selepas melebihi kadar pemprosesan yang ditetapkan.
burst=20 nodelay bermakna 20 permintaan ini akan diproses serta-merta tanpa berlengah-lengah, yang bersamaan dengan pengendalian perkara-perkara khas. Walau bagaimanapun, walaupun 20 permintaan pecah ini diproses serta-merta, permintaan seterusnya tidak akan diproses serta-merta. burst=20 adalah bersamaan dengan menduduki 20 lubang dalam baris gilir cache Walaupun permintaan diproses, 20 kedudukan ini hanya boleh dikeluarkan setiap 100ms. Ini mencapai kesan kelajuan yang stabil, tetapi trafik mengejut juga boleh dikendalikan seperti biasa.
3. Hadkan bilangan sambungan serentak
modul ngx_http_limit_conn_module nginx menyediakan fungsi mengehadkan bilangan sambungan sumber Hanya gunakan arahan limit_conn_zone dan limit_conn.
limit_conn perip 20: Kunci yang sepadan ialah $binary_remote_addr, yang bermaksud bahawa satu IP terhad untuk menahan sehingga 20 sambungan pada masa yang sama. limit_conn perserver 100: Kekunci yang sepadan ialah $server_name, yang menunjukkan jumlah bilangan sambungan serentak yang boleh dikendalikan oleh hos maya (pelayan) pada masa yang sama. Ambil perhatian bahawa sambungan ini hanya dikira selepas pengepala permintaan diproses oleh pelayan bahagian belakang.
Atas ialah kandungan terperinci Bagaimana untuk melaksanakan pengehadan semasa Nginx. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

NginxUnit menyokong pelbagai bahasa pengaturcaraan dan dilaksanakan melalui reka bentuk modular. 1. Memuatkan Modul Bahasa: Muatkan modul yang sepadan mengikut fail konfigurasi. 2. Permulaan Permohonan: Jalankan kod aplikasi apabila bahasa panggilan berjalan. 3. Permintaan Pemprosesan: Teruskan permintaan kepada contoh permohonan. 4. Pulangan Respons: Kembalikan respons yang diproses kepada pelanggan.

Nginx dan Apache mempunyai kelebihan dan kekurangan mereka sendiri dan sesuai untuk senario yang berbeza. 1.Nginx sesuai untuk senario penggunaan sumber yang tinggi dan rendah. 2. Apache sesuai untuk senario di mana konfigurasi kompleks dan modul yang kaya diperlukan. Dengan membandingkan ciri teras mereka, perbezaan prestasi, dan amalan terbaik, anda boleh membantu anda memilih perisian pelayan yang paling sesuai dengan keperluan anda.

Soalan: Bagaimana untuk memulakan nginx? Jawapan: Pasang Nginx Startup Nginx Verification Nginx adalah nginx mula meneroka pilihan permulaan lain secara automatik Mula nginx

Bagaimana untuk mengesahkan sama ada nginx dimulakan: 1. Gunakan baris arahan: status sistem sistem nginx (linux/unix), netstat -ano | Findstr 80 (Windows); 2. Periksa sama ada port 80 dibuka; 3. Semak mesej permulaan Nginx dalam log sistem; 4. Gunakan alat pihak ketiga, seperti Nagios, Zabbix, dan Icinga.

Untuk menutup perkhidmatan nginx, ikuti langkah -langkah berikut: Tentukan jenis pemasangan: Red Hat/CentOS (status SistemCTL nginx) atau debian/ubuntu (status nginx) menghentikan perkhidmatan: Red Hat/CentOS (SystemCtl Stop Nginx) atau Debian/Ubuntu (perkhidmatan Nginx) (Syst

Bagaimana cara mengkonfigurasi nginx di Windows? Pasang Nginx dan buat konfigurasi hos maya. Ubah suai fail konfigurasi utama dan sertakan konfigurasi hos maya. Mulakan atau Muat semula Nginx. Uji konfigurasi dan lihat laman web. Selektif membolehkan SSL dan mengkonfigurasi sijil SSL. Selektif tetapkan firewall untuk membolehkan trafik port 80 dan 443.

Pelayan tidak mempunyai kebenaran untuk mengakses sumber yang diminta, mengakibatkan ralat NGINX 403. Penyelesaian termasuk: Periksa keizinan fail. Semak konfigurasi .htaccess. Semak konfigurasi Nginx. Konfigurasikan keizinan Selinux. Semak peraturan firewall. Menyelesaikan masalah lain seperti masalah penyemak imbas, kegagalan pelayan, atau kesilapan lain yang mungkin.

Langkah -langkah untuk memulakan Nginx di Linux: Periksa sama ada Nginx dipasang. Gunakan SistemCTL Mula Nginx untuk memulakan perkhidmatan Nginx. Gunakan SistemCTL Dayakan NGINX untuk membolehkan permulaan automatik Nginx pada permulaan sistem. Gunakan Status SistemCTL Nginx untuk mengesahkan bahawa permulaan berjaya. Lawati http: // localhost dalam pelayar web untuk melihat halaman selamat datang lalai.


Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

AI Hentai Generator
Menjana ai hentai secara percuma.

Artikel Panas

Alat panas

DVWA
Damn Vulnerable Web App (DVWA) ialah aplikasi web PHP/MySQL yang sangat terdedah. Matlamat utamanya adalah untuk menjadi bantuan bagi profesional keselamatan untuk menguji kemahiran dan alatan mereka dalam persekitaran undang-undang, untuk membantu pembangun web lebih memahami proses mengamankan aplikasi web, dan untuk membantu guru/pelajar mengajar/belajar dalam persekitaran bilik darjah Aplikasi web keselamatan. Matlamat DVWA adalah untuk mempraktikkan beberapa kelemahan web yang paling biasa melalui antara muka yang mudah dan mudah, dengan pelbagai tahap kesukaran. Sila ambil perhatian bahawa perisian ini

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

MantisBT
Mantis ialah alat pengesan kecacatan berasaskan web yang mudah digunakan yang direka untuk membantu dalam pengesanan kecacatan produk. Ia memerlukan PHP, MySQL dan pelayan web. Lihat perkhidmatan demo dan pengehosan kami.

SublimeText3 versi Inggeris
Disyorkan: Versi Win, menyokong gesaan kod!

mPDF
mPDF ialah perpustakaan PHP yang boleh menjana fail PDF daripada HTML yang dikodkan UTF-8. Pengarang asal, Ian Back, menulis mPDF untuk mengeluarkan fail PDF "dengan cepat" dari tapak webnya dan mengendalikan bahasa yang berbeza. Ia lebih perlahan dan menghasilkan fail yang lebih besar apabila menggunakan fon Unicode daripada skrip asal seperti HTML2FPDF, tetapi menyokong gaya CSS dsb. dan mempunyai banyak peningkatan. Menyokong hampir semua bahasa, termasuk RTL (Arab dan Ibrani) dan CJK (Cina, Jepun dan Korea). Menyokong elemen peringkat blok bersarang (seperti P, DIV),