首頁 > 軟體

Nginx最大連線數設定詳解

2022-07-26 18:05:30

本文範例為大家分享了Nginx最大連線數設定的具體程式碼,供大家參考,具體內容如下

設定Nginx最大工作程序數##

worker_processes:最大工作程序數

work_connections:每個工作程序可以允許同時建立的外部連線數量。

修改最大可開啟檔案數

更改作業系統"程序最大可開啟檔案數"的設定

首先需要作業系統的root許可權,然後需要limits.conf主組態檔:

[root@localhost /]# vim /etc/security/limits.conf

在檔案中加入下面語句

* soft nofile 65535
* hard nofile 65535

注意:* 要加到檔案裡面,以上在limits.conf檔案中新增的兩句話的含義是
soft(應用軟體)級別限制的最大可開啟檔案數的限制
hard表示作業系統級別限制的最大可開啟檔案數的限制,
*表示所有使用者都生效。

儲存檔案後不會馬上生效。需要使用以下命令

ulimit -n 65535

使用ulimit -a 進行檢視

[root@localhost /]# ulimit -a
core file size          (blocks, -c) 0
data seg size           (kbytes, -d) unlimited
scheduling priority             (-e) 0
file size               (blocks, -f) unlimited
pending signals                 (-i) 14989
max locked memory       (kbytes, -l) 64
max memory size         (kbytes, -m) unlimited
open files                      (-n) 65535
pipe size            (512 bytes, -p) 8
POSIX message queues     (bytes, -q) 819200
real-time priority              (-r) 0
stack size              (kbytes, -s) 8192
cpu time               (seconds, -t) unlimited
max user processes              (-u) 14989
virtual memory          (kbytes, -v) unlimited
file locks                      (-x) unlimited

open files 已經變成65535了

更改Nginx“程序最大可開啟檔案數”的設定

開啟nginx.conf配合worker_rlimit_nofile屬性。

#user  nobody;
worker_processes  4;
#error_log  logs/error.log;
#error_log  logs/error.log  notice;
#error_log  logs/error.log  info;
#pid        logs/nginx.pid;
events {
    use epoll;
    worker_connections  65535;
}

驗證Nginx“程序最大可開啟檔案數”是否起作用

在linux中所有的程序都會有一個臨時的核心組態檔描述,存放路徑在/proc/程序號/limit

[root@localhost sbin]# ps -aux|grep nginx
root       1733  0.0  0.0  32816  1792 ?        Ss   17:38   0:00 nginx: master process ./nginx
nobody     1734  0.0  0.7  59952 29184 ?        S    17:38   0:00 nginx: worker process
nobody     1735  0.1  0.7  59952 29184 ?        S    17:38   0:00 nginx: worker process
nobody     1736  0.2  0.7  59952 29184 ?        S    17:38   0:00 nginx: worker process
nobody     1737  0.1  0.7  59952 28928 ?        S    17:38   0:00 nginx: worker process
root       1739  0.0  0.0 112824   980 pts/0    S+   17:38   0:00 grep --color=auto nginx
[root@localhost sbin]# cat /proc/1734/limits
Limit                     Soft Limit           Hard Limit           Units     
Max cpu time              unlimited            unlimited            seconds   
Max file size             unlimited            unlimited            bytes     
Max data size             unlimited            unlimited            bytes     
Max stack size            8388608              unlimited            bytes     
Max core file size        0                    unlimited            bytes     
Max resident set          unlimited            unlimited            bytes     
Max processes             14989                14989                processes 
Max open files            65535                65535                files     
Max locked memory         65536                65536                bytes     
Max address space         unlimited            unlimited            bytes     
Max file locks            unlimited            unlimited            locks     
Max pending signals       14989                14989                signals   
Max msgqueue size         819200               819200               bytes     
Max nice priority         0                    0                    
Max realtime priority     0                    0                    
Max realtime timeout      unlimited            unlimited            us   

其中Max open files 的Soft Limit和Hard Limit已經設定成了 65535

Max client計算方式

#充當伺服器時Nginx可同時承載的連線數量,是最大工作執行緒*每個執行緒允許的連線數量
max_client = worker_processes * worker_connections
#充當反向代理服務時,可同時承載的連線數量是最大工作執行緒*每個執行緒允許的連線數量/4
#(4)代表:瀏覽器會建立兩條連線到Nginx,Nginx也會建立兩條連線到後端伺服器。這樣就是4條了。
max_client = worker_processes * worker_connections/4

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支援it145.com。


IT145.com E-mail:sddin#qq.com