配置優化nginx處理PHP的請求

2021-08-31 03:19:08 字數 1599 閱讀 6985

第一步:接受請求,發現是php請求,轉向第二步。

第二步:通過socket的方式,連線php-fpm的fast-cgi,讓php-fpm處理請求。

第三步:獲得php-fpm處理結果,加上http報頭,返回給客戶端。

所以,我們要提高nginx的php併發效能,我們需要做這三步。

1.調大nginx的併發連線數( 調nginx.conf 的worker_connections 和 worker_processes)。

worker_connections : 每乙個worker程序能併發處理(發起)的最大連線數(包含所有連線數)

worker_processes :指明了nginx要開啟的程序數,據官方說法,一般開乙個就夠了,多開幾個,可以減少機器io帶來的影響。 一般為當前機器總cpu核心數的1到2倍。

參考:nginx 併發數問題思考:worker_connections,worker_processes與 max clients

nginx工作原理和優化、漏洞

2.調大php-fpm的併發連線數(調php-fpm.conf 的pm.max_children等)。

本人用的是ubuntu 14.04.4,php 5.5.9,以下目錄結構對其他伺服器環境可能不適用。

由於在 /etc/php5/fpm/php-fpm.conf 中並沒有找到 max_children ,於是使用以下命令進行查詢:

# 在/etc/php5/fpm 目錄下查詢所有檔案,並依次在每個檔案中查詢"max_children"

sudo find /etc/php5/fpm -name * | xargs grep "max_children"

終於在 /etc/php5/fpm/pool.d/www.conf 中找到了 max_children 等相關配置。

(php手冊)fastcgi 程序管理器(fpm)

php-fpm的配置和優化

php-fpm效能優化參考

php fpm php-fpm.conf設定詳解

3.增加系統的最大檔案數量限制(ulimit -n 65535)。

由於nginx處理php請求的第二步需要通過socket的方式和php-fpm通訊,它能新建的最大socket數受到系統最大開啟檔案數的限制。新裝的linux預設只有1024,所以必須增加系統最大開啟檔案數目。

ulimit -n 命令可以檢視當前系統最大開啟檔案數。

ulimit -n 65535 可以將系統最大開啟檔案數臨時修改為65535,然而退出登入後就會失效。

想要修改系統最大開啟檔案數,並永久生效:

vi /etc/security/limits.conf

# 新增如下的行

* soft noproc 11000

* hard noproc 11000

* soft nofile 65535

* hard nofile 65535

說明:

* 代表針對所有使用者

noproc 是代表最大程序數

nofile 是代表最大檔案開啟數

ulimit -n 修改

linux有效修改max open files/ulimit -n

nginx配置優化

worker processes指令控制工作程序數 worker processes 1 其預設值為1,這意味著nginx只執行乙個worker。該值應根據可用核心數,磁碟,網路子系統,伺服器負載等更改為最佳值。我們可以將值設定為可用的核心數。使用lscpu確定可用的核心數 lscpu archit...

Nginx配置優化

由於nginx處理php請求的第二步需要通過socket的方式和php fpm通訊,它能新建的最大socket數受到系統最大開啟檔案數的限制。新裝的linux預設只有1024,所以必須增加系統最大開啟檔案數目。ulimit n 命令可以檢視當前系統最大開啟檔案數。ulimit n 65535 可以將...

Nginx優化配置

user nobody 工作程序數,一般設定為cpu核心數 客戶端鏈結超時時間 keepalive timeout 65 gzip on 當配置多個server節點時,預設server names的快取區大小就不夠了,需要手動設定大一點 server names hash bucket size 5...