1. 程式人生 > >PHP php-fpm.conf 詳解

PHP php-fpm.conf 詳解

pid = run/php-fpm.pid
#pid設定,預設在安裝目錄中的var/run/php-fpm.pid,建議開啟
 
error_log = log/php-fpm.log
#錯誤日誌,預設在安裝目錄中的var/log/php-fpm.log
 
log_level = notice
#錯誤級別. 可用級別為: alert(必須立即處理), error(錯誤情況), warning(警告情況), notice(一般重要資訊), debug(除錯資訊). 預設: notice.
 
emergency_restart_threshold = 60
emergency_restart_interval = 60s
#表示在emergency_restart_interval所設值內出現SIGSEGV或者SIGBUS錯誤的php-cgi程序數如果超過 emergency_restart_threshold個,php-fpm就會優雅重啟。這兩個選項一般保持預設值。
 
process_control_timeout = 0
#設定子程序接受主程序複用訊號的超時時間. 可用單位: s(秒), m(分), h(小時), 或者 d(天) 預設單位: s(秒). 預設值: 0.
 
daemonize = yes
#後臺執行fpm,預設值為yes,如果為了除錯可以改為no。在FPM中,可以使用不同的設定來執行多個程序池。 這些設定可以針對每個程序池單獨設定。
 
listen = 127.0.0.1:9000
#fpm監聽埠,即nginx中php處理的地址,一般預設值即可。可用格式為: ‘ip:port’, ‘port’, ‘/path/to/unix/socket’. 每個程序池都需要設定.
 
listen.backlog = -1
#backlog數,-1表示無限制,由作業系統決定,此行註釋掉就行。backlog含義參考:
http://www.3gyou.cc/?p=41
 
listen.allowed_clients = 127.0.0.1
#允許訪問FastCGI程序的IP,設定any為不限制IP,如果要設定其他主機的nginx也能訪問這臺FPM程序,listen處要設定成本地可被訪問的IP。預設值是any。每個地址是用逗號分隔. 如果沒有設定或者為空,則允許任何伺服器請求連線
 
listen.owner = www
listen.group = www
listen.mode = 0666
#unix socket設定選項,如果使用tcp方式訪問,這裡註釋即可。
 
user = www
group = www
#啟動程序的帳戶和組
 
pm = dynamic #對於專用伺服器,pm可以設定為static。
#如何控制子程序,選項有static和dynamic。如果選擇static,則由pm.max_children指定固定的子程序數。如果dm設定為 dynamic,那麼pm.max_children引數失效,後面3個引數生效。
pm.max_children #,子程序最大數
pm.start_servers #,啟動時的程序數
pm.min_spare_servers #,保證空閒程序數最小值,如果空閒程序小於此值,則建立新的子程序
pm.max_spare_servers #,保證空閒程序數最大值,如果空閒程序大於此值,此進行清理
 
pm.max_requests = 1000
#設定每個子程序重生之前服務的請求數. 對於可能存在記憶體洩漏的第三方模組來說是非常有用的. 如果設定為 ’0′ 則一直接受請求. 等同於 PHP_FCGI_MAX_REQUESTS 環境變數. 預設值: 0.
 
pm.status_path = /status
#FPM狀態頁面的網址. 如果沒有設定, 則無法訪問狀態頁面. 預設值: none. munin監控會使用到
 
ping.path = /ping
#FPM監控頁面的ping網址. 如果沒有設定, 則無法訪問ping頁面. 該頁面用於外部檢測FPM是否存活並且可以響應請求. 請注意必須以斜線開頭 (/)。
 
ping.response = pong
#用於定義ping請求的返回相應. 返回為 HTTP 200 的 text/plain 格式文字. 預設值: pong.
 
request_terminate_timeout = 0
#設定單個請求的超時中止時間. 該選項可能會對php.ini設定中的’max_execution_time’因為某些特殊原因沒有中止執行的指令碼有用. 設定為 ’0′ 表示 ‘Off’.當經常出現502錯誤時可以嘗試更改此選項。
 
request_slowlog_timeout = 10s
#當一個請求該設定的超時時間後,就會將對應的PHP呼叫堆疊資訊完整寫入到慢日誌中. 設定為 ’0′ 表示 ‘Off’
 
slowlog = log/$pool.log.slow
#慢請求的記錄日誌,配合request_slowlog_timeout使用
 
rlimit_files = 1024
#設定檔案開啟描述符的rlimit限制. 預設值: 系統定義值預設可開啟控制代碼是1024,可使用 ulimit -n檢視,ulimit -n 2048修改。
 
rlimit_core = 0
#設定核心rlimit最大限制值. 可用值: ‘unlimited’ 、0或者正整數. 預設值: 系統定義值.
 
chroot =
#啟動時的Chroot目錄. 所定義的目錄需要是絕對路徑. 如果沒有設定, 則chroot不被使用.
 
chdir =
#設定啟動目錄,啟動時會自動Chdir到該目錄. 所定義的目錄需要是絕對路徑. 預設值: 當前目錄,或者/目錄(chroot時)
 
catch_workers_output = yes
#重定向執行過程中的stdout和stderr到主要的錯誤日誌檔案中. 如果沒有設定, stdout 和 stderr 將會根據FastCGI的規則被重定向到 /dev/null . 預設值: 空.

另附豆瓣技術貼:https://www.douban.com/note/315222037/

1、php-fpm優化引數介紹
他們分別是:pm、pm.max_children、pm.start_servers、pm.min_spare_servers、pm.max_spare_servers。

pm:表示使用那種方式,有兩個值可以選擇,就是static(靜態)或者dynamic(動態)。
在更老一些的版本中,dynamic被稱作apache-like。這個要注意看配置檔案的說明。


下面4個引數的意思分別為:

pm.max_children:靜態方式下開啟的php-fpm程序數量
pm.start_servers:動態方式下的起始php-fpm程序數量
pm.min_spare_servers:動態方式下的最小php-fpm程序數
pm.max_spare_servers:動態方式下的最大php-fpm程序數量

區別:

如果dm設定為 static,那麼其實只有pm.max_children這個引數生效。系統會開啟設定數量的php-fpm程序。
如果dm設定為 dynamic,那麼pm.max_children引數失效,後面3個引數生效。
系統會在php-fpm執行開始 的時候啟動pm.start_servers個php-fpm程序,
然後根據系統的需求動態在pm.min_spare_servers和pm.max_spare_servers之間調整php-fpm程序數


2、伺服器具體配置
對於我們的伺服器,選擇哪種執行方式比較好呢?事實上,跟Apache一樣,執行的PHP程式在執行完成後,或多或少會有記憶體洩露的問題。
這也是為什麼開始的時候一個php-fpm程序只佔用3M左右記憶體,執行一段時間後就會上升到20-30M的原因了。
對於記憶體大的伺服器(比如8G以上)來說,指定靜態的max_children實際上更為妥當,因為這樣不需要進行額外的程序數目控制,會提高效率。
因為頻繁開關php-fpm程序也會有時滯,所以記憶體夠大的情況下開靜態效果會更好。數量也可以根據 記憶體/30M 得到,比如8GB記憶體可以設定為100,
那麼php-fpm耗費的記憶體就能控制在 2G-3G的樣子。如果記憶體稍微小點,比如1G,那麼指定靜態的程序數量更加有利於伺服器的穩定。
這樣可以保證php-fpm只獲取夠用的記憶體,將不多的記憶體分配給其他應用去使用,會使系統的執行更加暢通。
對於小記憶體的伺服器來說,比如256M記憶體的VPS,即使按照一個20M的記憶體量來算,10個php-cgi程序就將耗掉200M記憶體,那系統的崩潰就應該很正常了。
因此應該儘量地控制php-fpm程序的數量,大體明確其他應用佔用的記憶體後,給它指定一個靜態的小數量,會讓系統更加平穩一些。或者使用動態方式,
因為動態方式會結束掉多餘的程序,可以回收釋放一些記憶體,所以推薦在記憶體較少的伺服器或VPS上使用。具體最大數量根據 記憶體/20M 得到。
比如說512M的VPS,建議pm.max_spare_servers設定為20。至於pm.min_spare_servers,則建議根據伺服器的負載情況來設定,比如伺服器上只是部署php環境的話,比較合適的值在5~10之間。

本伺服器配置

1、伺服器基本資訊:
硬碟:資料盤30G、系統盤20G
記憶體:1.5G
CPU:雙核
系統:CentOS 6.3 64位
頻寬:獨享2M
2、部署的應用
Git、SVN、Apache、Tomcat、PHP、Nginx、Mysql、JDK
3、優化後的引數
pm = dynamic
pm.start_servers = 5
pm.min_spare_servers = 2
pm.max_spare_servers = 8

 

pm.max_requests = 500

設定每個子程序重生之前服務的請求數. 對於可能存在記憶體洩漏的第三方模組來說是非常有用的. 如果設定為 ’0′ 則一直接受請求. 等同於 PHP_FCGI_MAX_REQUESTS 環境變數. 預設值: 0.
這段配置的意思是,當一個 PHP-CGI 程序處理的請求數累積到 500 個後,自動重啟該程序。

但是為什麼要重啟程序呢?

一般在專案中,我們多多少少都會用到一些 PHP 的第三方庫,這些第三方庫經常存在記憶體洩漏問題,如果不定期重啟 PHP-CGI 程序,勢必造成記憶體使用量不斷增長。因此 PHP-FPM 作為 PHP-CGI 的管理器,提供了這麼一項監控功能,對請求達到指定次數的 PHP-CGI 程序進行重啟,保證記憶體使用量不增長。

正是因為這個機制,在高併發的站點中,經常導致 502 錯誤,我猜測原因是 PHP-FPM 對從 NGINX 過來的請求佇列沒處理好。不過我目前用的還是 PHP 5.3.2,不知道在 PHP 5.3.3 中是否還存在這個問題。

目前我們的解決方法是,把這個值儘量設定大些,儘可能減少 PHP-CGI 重新 SPAWN 的次數,同時也能提高總體效能。在我們自己實際的生產環境中發現,記憶體洩漏並不明顯,因此我們將這個值設定得非常大(204800)。大家要根據自己的實際情況設定這個值,不能盲目地加大。