這次給大家帶來的是php-fpm.conf重要參數詳解,下面是具體的使用安裝教程,我們一起來看一下。
pid = run/php-fpm.pid #pid設定,預設在安裝目錄中的var/run/php-fpm.pid,建議開啟error_log = log/php-fpm.log#錯誤記錄檔,預設在安裝目錄中的var/log/php-fpm.loglog_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表示無限制,由作業系統決定,此行注釋掉就行。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指定固定的子進程數。如果選擇dynamic,則由下開參數決定: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 . 預設值: 空.
php-fpm參數調優
pm = dynamic;
表示使用哪種進程數量管理方式
dynamic表示php-fpm進程數是動態,最開始是pm.start_servers指定的數量,如果請求較多,則會自動增加,保證閒置進程數不小於pm.min_spare_servers,如果進程數較多,也會進行相應清理,保證多餘的進程數不多於pm.max_spare_serversstatic表示php-fpm進程數是靜態, 進程數自始至終都是pm.max_children指定的數量,不再增加或減少pm.max_children = 300; 靜態方式下開啟的php-fpm進程數量pm.start_servers = 20; 動態方式下的起始php-fpm進程數量pm.min_spare_servers = 5; 動態方式下的最小php-fpm進程數量pm.max_spare_servers = 35; 動態方式下的最大php-fpm進程數量如果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進程數那麼,對於我們的伺服器,選擇哪種pm方式比較好呢?事實上,跟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之間。在4G記憶體的伺服器上200就可以(我的1G測試機,開64個是最好的,建議使用壓力測試擷取最佳值)pm.max_requests = 10240;nginx php-fpm配置過程中最大問題是內泄漏出問題:伺服器的負載不大,但是記憶體佔用迅速增加,很快吃掉記憶體接著開始吃交換分區,系統很快掛掉!其實根據官方的介紹,php-cgi不存在記憶體流失,每個請求完成後php-cgi會回收記憶體,但是不會釋放給作業系統,這樣就會導致大量記憶體被php-cgi佔用。官方的解決辦法是降低PHP_FCGI_MAX_REQUESTS的值,如果用的是php-fpm,對應的php-fpm.conf中的就是max_requests,該值的意思是發送多少個請求後會重啟該線程,我們需要適當降低這個值,用以讓php-fpm自動的釋放記憶體,不是大部分網上說的51200等等,實際上還有另一個跟它有關聯的值max_children,這個是每次php-fpm會建立多少個進程,這樣實際上的記憶體消耗是max_children*max_requests*每個請求使用記憶體,根據這個我們可以預估一下記憶體的使用方式,就不用再寫指令碼去kill了。request_terminate_timeout = 30;最大執行時間, 在php.ini中也可以進行配置(max_execution_time)request_slowlog_timeout = 2; 開啟慢日誌slowlog = log/$pool.log.slow; 慢日誌路徑rlimit_files = 1024; 增加php-fpm開啟檔案描述符的限制
php-fpm.conf的參數明說大家只要多看幾遍應該就可能記住了,至於 php-fpm效能方案應該根據實際情況而定,多測試幾次得出最佳配置方案
相信看了這些案例你已經掌握了方法,更多精彩請關注php中文網其它相關文章!
相關閱讀:
java演算法中的關於二分尋找和折半尋找的執行個體詳解
javascript折半尋找詳解_javascript技巧
javascript 折半尋找字元在數組中的位置(有序列表)_javascript技巧