配置優化nginx處理PHP的請求
第一步:接受請求,發現是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