nginx反向代理优化(文件描述符)
lsof工具
文件描述符是一个简单的整数,用以标明每一个被进程所打开的文件和socket。第一个打开的文件是0,第二个是1,依此类推。Linux操作系统通常给每个进程能打开的文件数量强加一个限制,Linux通常有一个系统级1024的限制。
随着并发的增大,原有系统默认的1024个文件描述符肯定会不够用,时间越长,系统可能会报如下错误:
open files limits…..
查看nginx进程所占用的文件描述符,可以执行命令:
<code>lsof <span>| grep nginx</span></code>
部分结果
<code>nginx <span>6845</span> nobody <span>6</span>u <span>IPv4</span><span>179045</span> 0t<span>0</span><span>TCP</span> *<span>:http</span> (<span>LISTEN</span>) nginx <span>6845</span> nobody <span>7</span>u <span>IPv4</span><span>179046</span> 0t<span>0</span><span>TCP</span> *<span>:ddi-tcp-</span><span>1</span> (<span>LISTEN</span>) nginx <span>6845</span> nobody <span>8</span>u unix <span>0xffff88005eda0c80</span> 0t<span>0</span><span>179050</span> socket nginx <span>6845</span> nobody <span>9</span>u <span>REG</span><span>0</span>,<span>9</span><span>0</span><span>3660</span> anon_inode nginx <span>6845</span> nobody <span>10</span>u <span>REG</span><span>0</span>,<span>9</span><span>0</span><span>3660</span> anon_inode</code>
*注:第二行是nginx的进程编号
<code><span># 统计nginx进程打开了多少个文件数可以用下边的命令</span>lsof <span>|grep nginx|wc –l</span></code>
方法1:
上边部分结果的第二列是nginx的进程号
<code><span>cd</span> /prec/<span>6845</span></code>
可以看到这个进程生成的文件,然后看limits文件
<code>more limits</code>
第八行,Max open files是51200,(默认是1024),这是因为
我在nginx.conf里面顶格加了一行:
<code>worker_rlimit_nofile 51200;</code>
方法二:
执行:
<code>ulimit <span>-a</span></code>
执行:
<code>ulimit <span>-SHn</span><span>65535</span></code>
即可
方法三:
<code>[root<span>@localhost</span><span>6845</span>]# sysctl -a | grep <span>file</span>-<span>max</span> fs.<span>file</span>-<span>max</span> = <span>201604</span> [root<span>@localhost</span><span>6845</span>]#</code>
执行:
<code>[root<span>@localhost</span><span>6845</span>]# sysctl -w fs.<span>file</span>-<span>max</span>=<span>65535</span> fs.<span>file</span>-<span>max</span> = <span>65535</span> [root<span>@localhost</span><span>6845</span>]# sysctl -a | grep <span>file</span>-<span>max</span> fs.<span>file</span>-<span>max</span> = <span>65535</span></code>
要想永久生效编辑:
<code>vim /etc/sysctl<span>.conf</span></code>
文件,添加如下一行:
<code>fs.<span>file</span>-<span>max</span>=<span>65535</span></code>
然后执行如下命令使生效:
<code>sysctl <span>-p</span></code>
以上就介绍了nginx反向代理优化(文件描述符),包括了方面的内容,希望对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

AI Hentai Generator
Menjana ai hentai secara percuma.

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



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.

Langkah -langkah untuk membuat imej Docker: Tulis Dockerfile yang mengandungi arahan membina. Bina imej di terminal, menggunakan arahan membina Docker. Tag imej dan tetapkan nama dan tag menggunakan arahan tag docker.

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

Di Linux, gunakan arahan berikut untuk memeriksa sama ada nginx dimulakan: Hakim status SistemCTL Nginx berdasarkan output arahan: Jika "Aktif: Aktif (Running)" dipaparkan, Nginx dimulakan. Jika "aktif: tidak aktif (mati)" dipaparkan, nginx dihentikan.

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.

Bagaimana untuk memperbaiki kesilapan dilarang nginx 403? Semak keizinan fail atau direktori; 2. Semak .htaccess File; 3. Semak fail konfigurasi nginx; 4. Mulakan semula nginx. Penyebab lain yang mungkin termasuk peraturan firewall, tetapan selinux, atau isu aplikasi.
