


Bagaimana untuk mengoptimumkan kernel konkurensi tinggi Nginx
Apakah itu konkurensi tinggi?
Parameter kernel Linux lalai mempertimbangkan senario yang paling biasa dan tidak sesuai untuk aplikasi web yang menyokong serentak tinggi akses. pelarasan pada parameter kernel adalah berbeza. Berikut ialah parameter rangkaian TCP yang paling biasa yang membolehkan nginx menyokong lebih banyak permintaan serentak
Ini memerlukan pengubahsuaian /etc/sysctl.conf untuk menukar parameter kernel.
- Kaedah konfigurasi
Analisis terperinci konfigurasi
# menunjukkan bahawa satu proses adalah besar Bilangan pemegang yang boleh dibuka; fs.file-max = 999999
net.ipv4.tcp_tw_reuse = 1
#Apabila keepalive dimulakan, kekerapan tcp menghantar mesej keepalive ialah 2 jam, menetapkannya kepada 10 minit boleh membersihkan pautan yang tidak sah dengan lebih cepat.
ner.ipv4.tcp_keepalive_time = 600
#Apabila pelayan menutup pautan secara aktif, masa maksimum soket kekal dalam keadaan fin_wait_2
net.ipv4.tcp_fin_timeout = 30
#Parameter ini menunjukkan bilangan maksimum soket masa_tunggu yang dibenarkan oleh sistem pengendalian ia melebihi Dengan nombor ini, soket time_wait akan dikosongkan serta-merta dan mesej amaran akan dicetak.
#Parameter ini lalai kepada 180000. Soket tunggu_masa terlalu banyak akan memperlahankan pelayan web.net.ipv4.tcp_max_tw_buckets = 5000
#Tentukan julat nilai port tempatan untuk pautan udp dan tcp.
net.ipv4.ip_local_port_range = 1024 65000
# mentakrifkan nilai minimum, nilai lalai dan nilai maksimum untuk tcp menerima cache.
net.ipv4.tcp_rmem = 10240 87380 12582912
#Tentukan nilai minimum, nilai lalai dan nilai maksimum tcp send cache.
net.ipv4.tcp_wmem = 10240 87380 12582912
#Apabila kad rangkaian menerima paket data lebih cepat daripada kelajuan pemprosesan kernel, akan ada baris gilir untuk menyimpan paket data ini. Parameter ini mewakili nilai maksimum baris gilir.
net.core.netdev_max_backlog = 8096
# Menunjukkan bahawa soket kernel menerima saiz penimbal lalai.
net.core.rmem_default = 6291456
# menunjukkan saiz lalai penimbal hantar soket kernel.
net.core.wmem_default = 6291456
# Menunjukkan bahawa soket kernel menerima saiz penimbal yang lebih besar.
net.core.rmem_max = 12582912
# menunjukkan saiz penimbal hantar soket kernel yang lebih besar.
net.core.wmem_max = 12582912
Nota: Empat konfigurasi di atas perlu dipertimbangkan secara menyeluruh berdasarkan logik perniagaan dan kos perkakasan sebenar; # tiada kaitan dengan prestasi. Digunakan untuk menyelesaikan tcp syn***.
net.ipv4.tcp_syncookies = 1
#Parameter ini menunjukkan panjang maksimum baris gilir permintaan syn yang diterima semasa fasa penubuhan jabat tangan tiga hala TCP lalai ialah 1024. Menetapkannya lebih besar boleh menghalang Linux daripada terlalu sibuk untuk menerima sambungan baharu apabila nginx sibuk. Permintaan pautan yang dimulakan pelanggan hilang.
net.ipv4.tcp_max_syn_backlog = 8192
#Parameter ini digunakan untuk menetapkan dan mendayakan kitar semula pantas timewait. Nilai lalai bagi pilihan
net.ipv4.tcp_tw_recycle = 1
ialah 128. Parameter ini digunakan untuk melaraskan bilangan sambungan TCP yang dimulakan oleh sistem pada masa yang sama Dalam permintaan konkurensi tinggi, nilai lalai boleh menyebabkan pautan ke tamat masa atau hantar semula, jadi ia perlu digabungkan dengan konkurensi tinggi Laraskan nilai ini berdasarkan bilangan permintaan.
net.core.somaxconn=262114
# pilihan digunakan untuk menetapkan bilangan maksimum soket tcp dalam sistem yang tidak dikaitkan dengan mana-mana pemegang fail pengguna. Jika jumlah ini melebihi, pautan anak yatim akan ditetapkan semula serta-merta dan mesej amaran akan dikeluarkan. Had ini menunjukkan bahawa untuk mengelakkan dos mudah***, anda tidak perlu terlalu bergantung pada had ini atau mengurangkan nilai ini Dalam lebih banyak kes, tingkatkan nilai ini.
net.ipv4.tcp_max_orphans=262114
Untuk kemudahan penggunaan, anda boleh copy terus di bawah
net.ipv4.tcp_tw_reuse = 1 fs.file-max = 999999 net.ipv4.tcp_fin_timeout = 30 ner.ipv4.tcp_keepalive_time = 600
Atas ialah kandungan terperinci Bagaimana untuk mengoptimumkan kernel konkurensi tinggi Nginx. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

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

Video Face Swap
Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Artikel Panas

Alat panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas

Anda boleh menanyakan nama kontena Docker dengan mengikuti langkah -langkah: Senaraikan semua bekas (Docker PS). Tapis senarai kontena (menggunakan arahan grep). Mendapat nama kontena (terletak di lajur "Nama").

Cara mengkonfigurasi nama domain Nginx pada pelayan awan: Buat rekod yang menunjuk ke alamat IP awam pelayan awan. Tambah blok hos maya dalam fail konfigurasi Nginx, menyatakan port pendengaran, nama domain, dan direktori akar laman web. Mulakan semula nginx untuk memohon perubahan. Akses konfigurasi ujian nama domain. Nota Lain: Pasang sijil SSL untuk membolehkan HTTPS, pastikan firewall membenarkan trafik port 80, dan tunggu resolusi DNS berkuatkuasa.

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.

Kaedah yang boleh menanyakan versi nginx adalah: gunakan perintah nginx -v; Lihat arahan versi dalam fail nginx.conf; Buka halaman ralat Nginx dan lihat tajuk halaman.

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.

Buat bekas di Docker: 1. Tarik Imej: Docker Pull [Nama Cermin] 2. Buat bekas: Docker Run [Options] [Mirror Name] [Command] 3. Mulailah bekas: Docker Start [Nama Container]

Docker Container Startup Langkah: Tarik Imej Bekas: Run "Docker Pull [Mirror Name]". Buat bekas: Gunakan "Docker Buat [Pilihan] [Nama Mirror] [Perintah dan Parameter]". Mulakan bekas: Jalankan "Docker Start [Nama Container atau ID]". Semak Status Kontena: Sahkan bahawa bekas sedang berjalan dengan "Docker PS".

Memulakan pelayan Nginx memerlukan langkah-langkah yang berbeza mengikut sistem operasi yang berbeza: Sistem Linux/Unix: Pasang pakej Nginx (contohnya, menggunakan apt-get atau yum). Gunakan SystemCTL untuk memulakan perkhidmatan Nginx (contohnya, SUDO SystemCTL Mula Nginx). Sistem Windows: Muat turun dan pasang fail binari Windows. Mula Nginx menggunakan nginx.exe executable (contohnya, nginx.exe -c conf \ nginx.conf). Tidak kira sistem operasi yang anda gunakan, anda boleh mengakses IP pelayan
