(總結)Nginx使用的php-fpm的兩種進程管理方式及優化

(總結)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同樣的配置風格。php

在5.2.x版本中,php-fpm.conf中對於進程管理號稱是有兩種風格,一種是靜態(static)的,一種是相似於apache風格(apache-like)的。
按照文檔的說明,若是pm的style採用apache-like,啓動的進程數應該是和StartServers指定的同樣。不過通過數次的嘗試,會發現,實際上在這裏將pm的style配置成apache-like沒有起任何做用。也就是說,這裏的apache-like並無被實現。web

不過,在最新的5.3.x的配套php-fpm中,apache風格的進程管理已經被實現了。
對於進程的管理存在兩種風格——static和dynamic。和以前的版本的進程管理其實仍是同樣的,只是將apache-like改爲了dynamic,這樣更容易理解。apache

若是設置成static,php-fpm進程數自始至終都是pm.max_children指定的數量,再也不增長或減小。服務器

若是設置成dynamic,則php-fpm進程數是動態的,最開始是pm.start_servers指定的數量,若是請求較多,則會自動增長,保證空閒的進程數不小於pm.min_spare_servers,若是進程數較多,也會進行相應清理,保證多餘的進程數很少於pm.max_spare_servers。ide

這兩種不一樣的進程管理方式,能夠根據服務器的實際需求來進行調整。php-fpm

這裏先說一下涉及到這個的幾個參數,他們分別是pmpm.max_childrenpm.start_serverspm.min_spare_serverspm.max_spare_servers優化

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

下面4個參數的意思分別爲:spa

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

若是pm設置爲static,那麼其實只有pm.max_children這個參數生效。系統會開啓設置數量的php-fpm進程。

若是pm設置爲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之間。

相關文章
相關標籤/搜索