Linux學習總結(四十四)lnmp之php-fpm相關配置

1 php-fpm的進程pool

以前咱們在nginx 配置文件里加入了一句 include vhost/*.conf; 而後實現了各個虛擬主機的隔離,php-fpm 做爲一個獨立的服務,有沒有相似的操做呢? 答案是確定的。這裏咱們介紹一個php-fpm的 進程pool概念。pool 在lnmp架構,是分配出來解析php的進程資源集合。php-fpm能夠設置多個pool,在其中一個pool資源耗盡,會致使其餘站點沒法訪問資源,報502錯誤。有必要把站點進行分離,分別使用單獨的pool。咱們能夠在php-fpm.conf 中定義include,進而定義單獨的pool。具體過程以下:
vim /usr/local/php-fpm/etc/php-fpm.conf 更改內容以下php

[global]
pid = /usr/local/php-fpm/var/run/php-fpm.pid
error_log = /usr/local/php-fpm/var/log/php-fpm.log
include = etc/php-fpm.d/*.conf

cd /usr/local/php-fpm/etc/
mkdir php-fpm.d
cd php-fpm.d/
vim www.conf //寫入內容以下,添加第一個poolnginx

[www]
listen = /tmp/www.sock
listen.mode = 666
user = php-fpm
group = php-fpm
pm = dynamic
pm.max_children = 50
pm.start_servers = 20
pm.min_spare_servers = 5
pm.max_spare_servers = 35
pm.max_requests = 500
rlimit_files = 1024

保存後 再編輯另外的配置文件,再建立一個pool
vim test.confvim

[test]
listen = /tmp/test.sock
listen.mode = 666
user = php-fpm
group = php-fpm
pm = dynamic
pm.max_children = 50
pm.start_servers = 20
pm.min_spare_servers = 5
pm.max_spare_servers = 35
pm.max_requests = 500
rlimit_files = 1024

這樣有了兩個子配置文件,也就是建立了兩個pool了,兩個pool監聽了不一樣的socket,咱們就能夠在虛擬主機配置文件中給不一樣的虛擬主機定義不一樣的pool,從而達到互相隔離的目的。安全

測試下配置
/usr/local/php-fpm/sbin/php-fpm -t
重啓下服務
/etc/init.d/php-fpm restart
查看下/tmp/下的sock文件:
ls /tmp/*.sock
Linux學習總結(四十四)lnmp之php-fpm相關配置
再來查看下進程
ps aux |grep php-fpm
發現出現了www和test 兩個pool架構

2php-fpm慢執行日誌

若是一個php網站能夠訪問,就是訪問速度變慢了,咱們如何進一步去查找緣由呢?有沒有辦法追蹤到致使php解析變慢的細節,這裏就涉及到php-fpm的慢執行日誌。經過php-fpm的慢執行日誌,咱們能夠清晰的瞭解到php的腳本哪裏執行時間長,它能夠定位到具體的代碼行。如何開啓和查看該日誌,具體操做以下:
vim /usr/local/php-fpm/etc/php-fpm.d/www.conf
在最後面加入以下內容curl

request_slowlog_timeout = 1
slowlog = /usr/local/php-fpm/var/log/www-slow.log

第一行定義了超時時間,單位爲秒,也就是當php腳本執行時間超過1秒就會記錄日誌
第二行定義該日誌的路徑和名稱
咱們編寫一個php腳本測試socket

vim /data/wwwroot/test.com/slow.php
<?php
echo "just a slow running test";
sleep (3);
?>
curl -x127.0.0.1:80 test.com/slow.php

發現光標停頓了幾秒才輸出了just a slow running test
咱們去查看下慢執行日誌
cat /usr/local/php-fpm/var/log/www-slow.log
Linux學習總結(四十四)lnmp之php-fpm相關配置ide

3open_basedir

以前在lamp中已經接觸到該概念。配置它的目的就是爲了網站安全。httpd能夠針對每一個虛擬主機設置一個open_basedir,php-fpm一樣也能夠針對不一樣的pool設置不一樣的open_basedirphp-fpm

vim /usr/local/php-fpm/etc/php-fpm.d/test.conf  //在最後面加入
php_admin_value[open_basedir] = /data/wwwroot/test.com:/tmp/

4php-fpm 錯誤日誌

在lamp中咱們給php單獨定義過錯誤日誌,咱們在/usr/local/php-fpm/etc/php.ini中關閉錯誤信息的頁面顯示,定義錯誤日誌路徑和名稱,定義日誌級別。由於該配置文件與lamp中配置文件相同,都來源於php源碼包中的php.ini-production文件,因此各配置與以前的相同。這裏再也不贅述。學習

5php-fpm 進程管理

下面咱們介紹下php-fpm.conf中一段配置的含義

pm = dynamic  //動態進程管理,也能夠是static,靜態一次性啓動最大子進程數,不會變化。
 pm.max_children = 50 //最大子進程數,ps aux能夠查看
 pm.start_servers = 20 //啓動服務時會啓動的進程數
 pm.min_spare_servers = 5 //定義在空閒時段,子進程數的最少數量,若是達到這個數值時,php-fpm服務會自動派生新的子進程。
 pm.max_spare_servers = 35 //定義在空閒時段,子進程數的最大值,若是高於這個數值就開始清理空閒的子進程。
 pm.max_requests = 500  //定義一個子進程最多處理的請求數,也就是說在一個php-fpm的子進程最多能夠處理這麼多請求,當達到這個數值時,它會自動退出。
相關文章
相關標籤/搜索