Bagaimana untuk mengoptimumkan kernel konkurensi tinggi Nginx

WBOY
Lepaskan: 2023-05-15 17:52:06
ke hadapan
959 orang telah melayarinya

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
Salin selepas log masuk
#Parameter ditetapkan kepada 1, yang bermaksud bahawa soket dalam keadaan masa_tunggu dibenarkan untuk digunakan semula untuk pautan tcp baharu kepentingan kepada pelayan kerana sentiasa terdapat sejumlah besar pautan dalam keadaan masa_tunggu wujud

net.ipv4.tcp_tw_reuse = 1
Salin selepas log masuk

#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
Salin selepas log masuk

#Apabila pelayan menutup pautan secara aktif, masa maksimum soket kekal dalam keadaan fin_wait_2

net.ipv4.tcp_fin_timeout = 30
Salin selepas log masuk

#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
Salin selepas log masuk

#Tentukan julat nilai port tempatan untuk pautan udp dan tcp.

net.ipv4.ip_local_port_range = 1024 65000
Salin selepas log masuk

# mentakrifkan nilai minimum, nilai lalai dan nilai maksimum untuk tcp menerima cache.

net.ipv4.tcp_rmem = 10240 87380 12582912
Salin selepas log masuk

#Tentukan nilai minimum, nilai lalai dan nilai maksimum tcp send cache.

net.ipv4.tcp_wmem = 10240 87380 12582912
Salin selepas log masuk

#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
Salin selepas log masuk

# Menunjukkan bahawa soket kernel menerima saiz penimbal lalai.

net.core.rmem_default = 6291456
Salin selepas log masuk

# menunjukkan saiz lalai penimbal hantar soket kernel.

net.core.wmem_default = 6291456
Salin selepas log masuk

# Menunjukkan bahawa soket kernel menerima saiz penimbal yang lebih besar.

net.core.rmem_max = 12582912
Salin selepas log masuk

# menunjukkan saiz penimbal hantar soket kernel yang lebih besar.

net.core.wmem_max = 12582912
Salin selepas log masuk

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
Salin selepas log masuk

#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
Salin selepas log masuk

#Parameter ini digunakan untuk menetapkan dan mendayakan kitar semula pantas timewait. Nilai lalai bagi pilihan

net.ipv4.tcp_tw_recycle = 1
Salin selepas log masuk

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
Salin selepas log masuk

# 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
Salin selepas log masuk

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
Salin selepas log masuk

Atas ialah kandungan terperinci Bagaimana untuk mengoptimumkan kernel konkurensi tinggi Nginx. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Label berkaitan:
sumber:yisu.com
Kenyataan Laman Web ini
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
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan
Tentang kita Penafian Sitemap
Laman web PHP Cina:Latihan PHP dalam talian kebajikan awam,Bantu pelajar PHP berkembang dengan cepat!