需要了解的引數是:pm
、pm.max_children
、pm.start_servers
、pm.min_spare_servers
、pm.max_spare_servers
。
pm
:表示使用那種方式,有兩個值可以選擇,就是static(靜態)或者dynamic(動態)。
在更老一些的版本中,dynamic被稱作apache-like。這個要注意看配置檔案的說明。
下面5個引數的意思分別為:
pm = dynamic 如何控制子程序,選項有static和dynamic
pm.max_children:靜態方式下開啟的php-fpm程序數量
pm.max_requests: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程序數。
對於我們的伺服器,選擇哪種執行方式比較好呢?事實上,跟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上使用。具體最大數量根據記憶體/30m
得到。
pm.start_servers
預設值計算公式:min_spare_servers + (max_spare_servers - min_spare_servers) / 2
。
比如說512m的vps,加入分配給php-fpm最大250m,建議pm.max_spare_servers
設定為250/30 ,約為8。至於pm.min_spare_servers
,則建議根據伺服器的負載情況來設定,比如伺服器上只是部署php環境的話,比較合適的值在2~5之間。
這裡面還有乙個問題,php-fpm因為一些第三方庫可能會引起記憶體洩漏,時間長了,占用的記憶體會比較多,像我們的伺服器現在就是50m左右,還好,有pm.max_requests這個引數,這個引數指定了乙個php-fpm子程序執行多少次之後重啟該程序。這個可能就要根據你的實際情況調整了。
硬碟:系統盤20g
記憶體:512m
cpu:1核
系統:centos 6.5 64位
頻寬:獨享1m
nginx php mysql
編輯/usr/local/php/etc/php-fpm.conf
:
pm = dynamic
pm.start_servers = 4
pm.min_spare_servers = 2
pm.max_spare_servers = 8
參考:
php fpm程序數優化方法
背景 自己的伺服器是雲伺服器,最近經常出現php fpm假死狀態,硬碟和記憶體都比較小,所以記憶體經常不夠使,通過linux命令檢視後,發現啟動php fpm程序數有20多個,占用了將近1g的記憶體,整個伺服器才1.5g的記憶體,最後通過對php fpm程序數優化解決了此問題,伺服器多節省出600m...
php fpm程序數優化方法
背景 最近將wordpress遷移至阿里雲。由於自己的伺服器是雲伺服器,硬碟和記憶體都比較小,所以記憶體經常不夠使,通過linux命令檢視後,發現啟動php fpm程序數有20多個,占用了將近1g的記憶體,整個伺服器才1.5g的記憶體,最後通過對php fpm程序數優化解決了此問題,伺服器多節省出6...
php fpm程序數優化方法
最近將wordpress遷移至阿里雲。由於自己的伺服器是雲伺服器,硬碟和記憶體都比較小,所以記憶體經常不夠使,通過linux命令檢視後,發現啟動php fpm程序數有20多個,占用了將近1g的記憶體,整個伺服器才1.5g的記憶體,最後通過對php fpm程序數優化解決了此問題,伺服器多節省出600m...