您好,登錄后才能下訂單哦!
Nginx如何使用的php-fpm進程管理方式及優化?針對這個問題,這篇文章詳細介紹了相對應的分析和解答,希望可以幫助更多想解決這個問題的小伙伴找到更簡單易行的方法。
PS:前段時間配置php-fpm的時候,無意中發現原來它還有兩種進程管理方式。與Apache類似,它的進程數也是可以根據設置分為動態和靜態的。
php-fpm目前主要又兩個分支,分別對應于php-5.2.x的版本和php-5.3.x的版本。在5.2.x的版本中,php-fpm.conf使用的是xml格式,而在新的5.3.x版本中,則是和php.ini一樣的配置風格。
在5.2.x版本中,php-fpm.conf
中對于進程管理號稱是有兩種風格,一種是靜態(static)的,一種是類似于apache風格(apache-like)的。
代碼如下:
Process manager settings <value name=”pm”> Sets style of controling worker process count. Valid values are 'static' and ‘apache-like' <value name=”style”>static</value>
按照文檔的說明,如果pm的style采用apache-like
,啟動的進程數應該是和StartServers指定的一樣。不過經過數次的嘗試,會發現,實際上在這里將pm的style配置成apache-like沒有起任何作用。也就是說,這里的apache-like并沒有被實現。
不過,在最新的5.3.x的配套php-fpm中,apache風格的進程管理已經被實現了。
代碼如下:
; Choose how the process manager will control the number of child processes. ; Possible Values: ; static - a fixed number (pm.max_children) of child processes; ; dynamic - the number of child processes are set dynamically based on the ; following directives: ; pm.max_children - the maximum number of children that can ; be alive at the same time. ; pm.start_servers - the number of children created on startup. ; pm.min_spare_servers - the minimum number of children in 'idle' ; state (waiting to process). If the number ; of 'idle' processes is less than this ; number then some children will be created. ; pm.max_spare_servers - the maximum number of children in 'idle' ; state (waiting to process). If the number ; of 'idle' processes is greater than this ; number then some children will be killed. ; Note: This value is mandatory. ;pm = dynamic pm = static
由上面一段文字可知,對于進程的管理存在兩種風格——static和dynamic。和之前的版本的進程管理其實還是一樣的,只是將apache-like改成了dynamic,這樣更容易理解。
如果設置成static,php-fpm進程數自始至終都是pm.max_children指定的數量,不再增加或減少。
如果設置成dynamic,則php-fpm進程數是動態的,最開始是pm.start_servers指定的數量,如果請求較多,則會自動增加,保證空閑的進程數不小于pm.min_spare_servers
,如果進程數較多,也會進行相應清理,保證多余的進程數不多于pm.max_spare_servers。
這兩種不同的進程管理方式,可以根據服務器的實際需求來進行調整。
這里先說一下涉及到這個的幾個參數,他們分別是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進程數。
那么,對于我們的服務器,選擇哪種執行方式比較好呢?事實上,跟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
,則建議根據服務器的負載情況來設置,比較合適的值在5~10之間。
關于Nginx如何使用的php-fpm進程管理方式及優化問題的解答就分享到這里了,希望以上內容可以對大家有一定的幫助,如果你還有很多疑惑沒有解開,可以關注億速云行業資訊頻道了解更多相關知識。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。