Nginx優化---連接超時與進程管理

配置Nginx實現連接超時

在企業網站中,爲了避免同一個客戶長時間佔用連接,造成資源浪費,可設置相應的連接超時參數,實現控制連接訪問時間

使用Fiddler工具查看connection參數

超時參數

Keepalive_ timeout
#設置連接保持超時時間,-般可只設置該參數,默認爲75秒,可根據
網站的情況設置,或者關閉,可在http段、server段、 或者location段
設置

Client_header_ timeout
#指定等待客戶端發送請求頭的超時時間

Client_ body_ _timeout
#設置請求體讀超時時間

更改Nginx運行進程數

1.在高併發場景,需要啓動更多的Nginx進程以保證快速響應,以處理用戶的請求,避免造成阻塞

2.可以使用ps aux命令查看Nginx運行進程的個數

3.更改進程數的配置方法:配置文件,修改進程配置參數

4.修改配置文件的worker_ _processes參數

(1)一般設爲CPU的個數或者核數

(2)在高併發情況下可設置爲CPU個數或者核數的2倍

5.運行進程數多一些, 響應訪問請求時,Nginx就不會臨時啓動新的進程提供服務,減少了系統的開銷,提升了服務速度

6.使用ps aux查看運行進程數的變化情況

7.默認情況,Nginx的多個進程可能跑在一一個CPU上,可以分配不同的進程給不同的CPU處理,充分利用硬件多3核多CPU

8.在一臺4核物理服務器,可進行以下配置,將進程進行分配:Worker_ cpu affinity 0001 0010 0100 1000

實例演示

一、Nginx連接超時演示

修改nginx.conf配置文件

[root@localhost ~]# cd /usr/local/nginx/conf/
[root@localhost conf]# vim nginx.conf

#keepalive_timeout  0;
keepalive_timeout  65 180;     
#服務端和客戶端的超時時間,可在http\server\location中設置

client_header_timeout 80;     
#等待客戶端發送請求頭部超時時間,超時會發送408錯誤

client_body_timeout 80;          
#請求體超時時間

[root@localhost conf]# systemctl stop nginx
[root@localhost conf]# systemctl start nginx

二、Nginx進程管理演示

第一步:關閉虛擬機,添加CPU

在這裏插入圖片描述

第二步:查看此時Nginx進程信息

[root@localhost ~]# ps aux | grep nginx
root       1854  0.0  0.0  20544   608 ?        Ss   14:17   0:00 nginx: master process /usr/local/nginx/sbin/nginx
nginx      1855  0.0  0.0  23072  1392 ?        S    14:17   0:00 nginx: worker process
root       1859  0.0  0.0 112728   972 pts/0    S+   14:18   0:00 grep --color=auto nginx

第三步:修改配置文件

[root@localhost ~]# cd /proc/
[root@localhost proc]# cat cpuinfo   ##查看cpu核心數
processor       : 0   ##第一個CPU
...
processor       : 1   ##第二個CPU
...
[root@localhost proc]# vim /usr/local/nginx/conf/nginx.conf

#user  nobody;
worker_processes  2;
#修改核數相同或者2倍

worker_cpu_affinity 01 10;
#設置每個進程有不同的CPU處理
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章