溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

linux系統(tǒng)下的php-fpm參數(shù)配置介紹與參數(shù)優(yōu)化說明

發(fā)布時(shí)間:2021-09-02 09:43:19 來源:億速云 閱讀:131 作者:chen 欄目:開發(fā)技術(shù)

這篇文章主要介紹“l(fā)inux系統(tǒng)下的php-fpm參數(shù)配置介紹與參數(shù)優(yōu)化說明”,在日常操作中,相信很多人在linux系統(tǒng)下的php-fpm參數(shù)配置介紹與參數(shù)優(yōu)化說明問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”linux系統(tǒng)下的php-fpm參數(shù)配置介紹與參數(shù)優(yōu)化說明”的疑惑有所幫助!接下來,請跟著小編一起來學(xué)習(xí)吧!

php-fpm.conf重要參數(shù)詳解

pid = run/php-fpm.pid
#pid設(shè)置,默認(rèn)在安裝目錄中的var/run/php-fpm.pid,建議開啟

error_log = log/php-fpm.log
#錯(cuò)誤日志,默認(rèn)在安裝目錄中的var/log/php-fpm.log

log_level = notice
#錯(cuò)誤級(jí)別. 可用級(jí)別為: alert(必須立即處理), error(錯(cuò)誤情況), warning(警告情況), notice(一般重要信息), debug(調(diào)試信息). 默認(rèn): notice.

emergency_restart_threshold = 60
emergency_restart_interval = 60s
#表示在emergency_restart_interval所設(shè)值內(nèi)出現(xiàn)SIGSEGV或者SIGBUS錯(cuò)誤的php-cgi進(jìn)程數(shù)如果超過 emergency_restart_threshold個(gè),php-fpm就會(huì)優(yōu)雅重啟。這兩個(gè)選項(xiàng)一般保持默認(rèn)值。

process_control_timeout = 0
#設(shè)置子進(jìn)程接受主進(jìn)程復(fù)用信號(hào)的超時(shí)時(shí)間. 可用單位: s(秒), m(分), h(小時(shí)), 或者 d(天) 默認(rèn)單位: s(秒). 默認(rèn)值: 0.

daemonize = yes
#后臺(tái)執(zhí)行fpm,默認(rèn)值為yes,如果為了調(diào)試可以改為no。在FPM中,可以使用不同的設(shè)置來運(yùn)行多個(gè)進(jìn)程池。 這些設(shè)置可以針對每個(gè)進(jìn)程池單獨(dú)設(shè)置。

listen = 127.0.0.1:9000
#fpm監(jiān)聽端口,即nginx中php處理的地址,一般默認(rèn)值即可??捎酶袷綖? 'ip:port', 'port', '/path/to/unix/socket'. 每個(gè)進(jìn)程池都需要設(shè)置.

listen.backlog = -1
#backlog數(shù),-1表示無限制,由操作系統(tǒng)決定,此行注釋掉就行。

listen.allowed_clients = 127.0.0.1
#允許訪問FastCGI進(jìn)程的IP,設(shè)置any為不限制IP,如果要設(shè)置其他主機(jī)的nginx也能訪問這臺(tái)FPM進(jìn)程,listen處要設(shè)置成本地可被訪問的IP。默認(rèn)值是any。每個(gè)地址是用逗號(hào)分隔. 如果沒有設(shè)置或者為空,則允許任何服務(wù)器請求連接

listen.owner = www
listen.group = www
listen.mode = 0666
#unix socket設(shè)置選項(xiàng),如果使用tcp方式訪問,這里注釋即可。

user = www
group = www
#啟動(dòng)進(jìn)程的帳戶和組

pm = dynamic
#對于專用服務(wù)器,pm可以設(shè)置為static。
#如何控制子進(jìn)程,選項(xiàng)有static和dynamic。如果選擇static,則由pm.max_children指定固定的子進(jìn)程數(shù)。如果選擇dynamic,則由下開參數(shù)決定:
pm.max_children #,子進(jìn)程最大數(shù)
pm.start_servers #,啟動(dòng)時(shí)的進(jìn)程數(shù)
pm.min_spare_servers #,保證空閑進(jìn)程數(shù)最小值,如果空閑進(jìn)程小于此值,則創(chuàng)建新的子進(jìn)程
pm.max_spare_servers #,保證空閑進(jìn)程數(shù)最大值,如果空閑進(jìn)程大于此值,此進(jìn)行清理

pm.max_requests = 1000
#設(shè)置每個(gè)子進(jìn)程重生之前服務(wù)的請求數(shù). 對于可能存在內(nèi)存泄漏的第三方模塊來說是非常有用的. 如果設(shè)置為 '0' 則一直接受請求. 等同于 PHP_FCGI_MAX_REQUESTS 環(huán)境變量. 默認(rèn)值: 0.

pm.status_path = /status
#FPM狀態(tài)頁面的網(wǎng)址. 如果沒有設(shè)置, 則無法訪問狀態(tài)頁面. 默認(rèn)值: none. munin監(jiān)控會(huì)使用到

ping.path = /ping
#FPM監(jiān)控頁面的ping網(wǎng)址. 如果沒有設(shè)置, 則無法訪問ping頁面. 該頁面用于外部檢測FPM是否存活并且可以響應(yīng)請求. 請注意必須以斜線開頭 (/)。

ping.response = pong
#用于定義ping請求的返回相應(yīng). 返回為 HTTP 200 的 text/plain 格式文本. 默認(rèn)值: pong.

request_terminate_timeout = 0
#設(shè)置單個(gè)請求的超時(shí)中止時(shí)間. 該選項(xiàng)可能會(huì)對php.ini設(shè)置中的'max_execution_time'因?yàn)槟承┨厥庠驔]有中止運(yùn)行的腳本有用. 設(shè)置為 '0' 表示 'Off'.當(dāng)經(jīng)常出現(xiàn)502錯(cuò)誤時(shí)可以嘗試更改此選項(xiàng)。

request_slowlog_timeout = 10s
#當(dāng)一個(gè)請求該設(shè)置的超時(shí)時(shí)間后,就會(huì)將對應(yīng)的PHP調(diào)用堆棧信息完整寫入到慢日志中. 設(shè)置為 '0' 表示 'Off'

slowlog = log/$pool.log.slow
#慢請求的記錄日志,配合request_slowlog_timeout使用

rlimit_files = 1024
#設(shè)置文件打開描述符的rlimit限制. 默認(rèn)值: 系統(tǒng)定義值默認(rèn)可打開句柄是1024,可使用 ulimit -n查看,ulimit -n 2048修改。

rlimit_core = 0
#設(shè)置核心rlimit最大限制值. 可用值: 'unlimited' 、0或者正整數(shù). 默認(rèn)值: 系統(tǒng)定義值.

chroot =
#啟動(dòng)時(shí)的Chroot目錄. 所定義的目錄需要是絕對路徑. 如果沒有設(shè)置, 則chroot不被使用.

chdir =
#設(shè)置啟動(dòng)目錄,啟動(dòng)時(shí)會(huì)自動(dòng)Chdir到該目錄. 所定義的目錄需要是絕對路徑. 默認(rèn)值: 當(dāng)前目錄,或者/目錄(chroot時(shí))

catch_workers_output = yes
#重定向運(yùn)行過程中的stdout和stderr到主要的錯(cuò)誤日志文件中. 如果沒有設(shè)置, stdout 和 stderr 將會(huì)根據(jù)FastCGI的規(guī)則被重定向到 /dev/null . 默認(rèn)值: 空.

php-fpm參數(shù)調(diào)優(yōu)

pm = dynamic;

表示使用哪種進(jìn)程數(shù)量管理方式

dynamic表示php-fpm進(jìn)程數(shù)是動(dòng)態(tài)的,最開始是pm.start_servers指定的數(shù)量,如果請求較多,則會(huì)自動(dòng)增加,保證空閑的進(jìn)程數(shù)不小于pm.min_spare_servers,如果進(jìn)程數(shù)較多,也會(huì)進(jìn)行相應(yīng)清理,保證多余的進(jìn)程數(shù)不多于pm.max_spare_servers

static表示php-fpm進(jìn)程數(shù)是靜態(tài)的, 進(jìn)程數(shù)自始至終都是pm.max_children指定的數(shù)量,不再增加或減少

pm.max_children = 300; 靜態(tài)方式下開啟的php-fpm進(jìn)程數(shù)量
pm.start_servers = 20; 動(dòng)態(tài)方式下的起始php-fpm進(jìn)程數(shù)量
pm.min_spare_servers = 5; 動(dòng)態(tài)方式下的最小php-fpm進(jìn)程數(shù)量
pm.max_spare_servers = 35; 動(dòng)態(tài)方式下的最大php-fpm進(jìn)程數(shù)量

如果pm為static, 那么其實(shí)只有pm.max_children這個(gè)參數(shù)生效。系統(tǒng)會(huì)開啟設(shè)置數(shù)量的php-fpm進(jìn)程

如果pm為dynamic, 那么pm.max_children參數(shù)失效,后面3個(gè)參數(shù)生效。系統(tǒng)會(huì)在php-fpm運(yùn)行開始的時(shí)候啟動(dòng)pm.start_servers個(gè)php-fpm進(jìn)程,然后根據(jù)系統(tǒng)的需求動(dòng)態(tài)在pm.min_spare_servers和pm.max_spare_servers之間調(diào)整php-fpm進(jìn)程數(shù)

那么,對于我們的服務(wù)器,選擇哪種pm方式比較好呢?事實(shí)上,跟Apache一樣,運(yùn)行的PHP程序在執(zhí)行完成后,或多或少會(huì)有內(nèi)存泄露的問題。這也是為什么開始的時(shí)候一個(gè)php-fpm進(jìn)程只占用3M左右內(nèi)存,運(yùn)行一段時(shí)間后就會(huì)上升到20-30M的原因了。

對于內(nèi)存大的服務(wù)器(比如8G以上)來說,指定靜態(tài)的max_children實(shí)際上更為妥當(dāng),因?yàn)檫@樣不需要進(jìn)行額外的進(jìn)程數(shù)目控制,會(huì)提高效率。因?yàn)轭l繁開關(guān)php-fpm進(jìn)程也會(huì)有時(shí)滯,所以內(nèi)存夠大的情況下開靜態(tài)效果會(huì)更好。數(shù)量也可以根據(jù) 內(nèi)存/30M 得到,比如8GB內(nèi)存可以設(shè)置為100,那么php-fpm耗費(fèi)的內(nèi)存就能控制在 2G-3G的樣子。如果內(nèi)存稍微小點(diǎn),比如1G,那么指定靜態(tài)的進(jìn)程數(shù)量更加有利于服務(wù)器的穩(wěn)定。這樣可以保證php-fpm只獲取夠用的內(nèi)存,將不多的內(nèi)存分配給其他應(yīng)用去使用,會(huì)使系統(tǒng)的運(yùn)行更加暢通。

對于小內(nèi)存的服務(wù)器來說,比如256M內(nèi)存的VPS,即使按照一個(gè)20M的內(nèi)存量來算,10個(gè)php-cgi進(jìn)程就將耗掉200M內(nèi)存,那系統(tǒng)的崩潰就應(yīng)該很正常了。因此應(yīng)該盡量地控制php-fpm進(jìn)程的數(shù)量,大體明確其他應(yīng)用占用的內(nèi)存后,給它指定一個(gè)靜態(tài)的小數(shù)量,會(huì)讓系統(tǒng)更加平穩(wěn)一些?;蛘呤褂脛?dòng)態(tài)方式,因?yàn)閯?dòng)態(tài)方式會(huì)結(jié)束掉多余的進(jìn)程,可以回收釋放一些內(nèi)存,所以推薦在內(nèi)存較少的服務(wù)器或VPS上使用。具體最大數(shù)量根據(jù) 內(nèi)存/20M 得到。比如說512M的VPS,建議pm.max_spare_servers設(shè)置為20。至于pm.min_spare_servers,則建議根據(jù)服務(wù)器的負(fù)載情況來設(shè)置,比較合適的值在5~10之間。

在4G內(nèi)存的服務(wù)器上200就可以(我的1G測試機(jī),開64個(gè)是最好的,建議使用壓力測試獲取最佳值)

pm.max_requests = 10240;

nginx php-fpm配置過程中最大問題是內(nèi)泄漏出問題:服務(wù)器的負(fù)載不大,但是內(nèi)存占用迅速增加,很快吃掉內(nèi)存接著開始吃交換分區(qū),系統(tǒng)很快掛掉!其實(shí)根據(jù)官方的介紹,php-cgi不存在內(nèi)存泄漏,每個(gè)請求完成后php-cgi會(huì)回收內(nèi)存,但是不會(huì)釋放給操作系統(tǒng),這樣就會(huì)導(dǎo)致大量內(nèi)存被php-cgi占用。

官方的解決辦法是降低PHP_FCGI_MAX_REQUESTS的值,如果用的是php-fpm,對應(yīng)的php-fpm.conf中的就是max_requests,該值的意思是發(fā)送多少個(gè)請求后會(huì)重啟該線程,我們需要適當(dāng)降低這個(gè)值,用以讓php-fpm自動(dòng)的釋放內(nèi)存,不是大部分網(wǎng)上說的51200等等,實(shí)際上還有另一個(gè)跟它有關(guān)聯(lián)的值max_children,這個(gè)是每次php-fpm會(huì)建立多少個(gè)進(jìn)程,這樣實(shí)際上的內(nèi)存消耗是max_children*max_requests*每個(gè)請求使用內(nèi)存,根據(jù)這個(gè)我們可以預(yù)估一下內(nèi)存的使用情況,就不用再寫腳本去kill了。

request_terminate_timeout = 30;

最大執(zhí)行時(shí)間, 在php.ini中也可以進(jìn)行配置(max_execution_time)

request_slowlog_timeout = 2; 開啟慢日志
slowlog = log/$pool.log.slow; 慢日志路徑

rlimit_files = 1024; 增加php-fpm打開文件描述符的限制

php-fpm.conf的參數(shù)明說大家只要多看幾遍應(yīng)該就可能記住了,至于 php-fpm性能方案應(yīng)該根據(jù)實(shí)際情況而定,多測試幾次得出最佳配置方案

到此,關(guān)于“l(fā)inux系統(tǒng)下的php-fpm參數(shù)配置介紹與參數(shù)優(yōu)化說明”的學(xué)習(xí)就結(jié)束了,希望能夠解決大家的疑惑。理論與實(shí)踐的搭配能更好的幫助大家學(xué)習(xí),快去試試吧!若想繼續(xù)學(xué)習(xí)更多相關(guān)知識(shí),請繼續(xù)關(guān)注億速云網(wǎng)站,小編會(huì)繼續(xù)努力為大家?guī)砀鄬?shí)用的文章!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI