約定幾個目錄
休寧縣網(wǎng)站建設(shè)公司創(chuàng)新互聯(lián)建站,休寧縣網(wǎng)站設(shè)計制作,有大型網(wǎng)站制作公司豐富經(jīng)驗。已為休寧縣近1000家提供企業(yè)網(wǎng)站建設(shè)服務(wù)。企業(yè)網(wǎng)站搭建\外貿(mào)營銷網(wǎng)站建設(shè)要多少錢,請找那個售后服務(wù)好的休寧縣做網(wǎng)站的公司定做!
/usr/local/php/sbin/php-fpm
/usr/local/php/etc/php-fpm.conf
/usr/local/php/etc/php.ini
一,php-fpm的啟動參數(shù)
復(fù)制代碼代碼如下:
#測試php-fpm配置
/usr/local/php/sbin/php-fpm -t
/usr/local/php/sbin/php-fpm -c /usr/local/php/etc/php.ini -y/usr/local/php/etc/php-fpm.conf -t
#啟動php-fpm
/usr/local/php/sbin/php-fpm
/usr/local/php/sbin/php-fpm -c /usr/local/php/etc/php.ini -y/usr/local/php/etc/php-fpm.conf
#關(guān)閉php-fpm
kill -INT `cat /usr/local/php/var/run/php-fpm.pid`
#重啟php-fpm
kill -USR2 `cat /usr/local/php/var/run/php-fpm.pid`
二,php-fpm.conf重要參數(shù)詳解
復(fù)制代碼代碼如下:
pid = run/php-fpm.pid
#pid設(shè)置,默認在安裝目錄中的var/run/php-fpm.pid,建議開啟
error_log = log/php-fpm.log
#錯誤日志,默認在安裝目錄中的var/log/php-fpm.log
log_level = notice
#錯誤級別.可用級別為: alert(必須立即處理), error(錯誤情況), warning(警告情況), notice(一般重要信息), debug(調(diào)試信息).默認: notice.
emergency_restart_threshold = 60
emergency_restart_interval = 60s
#表示在emergency_restart_interval所設(shè)值內(nèi)出現(xiàn)SIGSEGV或者SIGBUS錯誤的php-cgi進程數(shù)如果超過 emergency_restart_threshold個,php-fpm就會優(yōu)雅重啟。這兩個選項一般保持默認值。
process_control_timeout = 0
#設(shè)置子進程接受主進程復(fù)用信號的超時時間.可用單位: s(秒), m(分), h(小時),或者 d(天)默認單位: s(秒).默認值: 0.
daemonize = yes
#后臺執(zhí)行fpm,默認值為yes,如果為了調(diào)試可以改為no。在FPM中,可以使用不同的設(shè)置來運行多個進程池。這些設(shè)置可以針對每個進程池單獨設(shè)置。
listen = 127.0.0.1:9000
#fpm監(jiān)聽端口,即nginx中php處理的地址,一般默認值即可??捎酶袷綖? 'ip:port', 'port','/path/to/unix/socket'.每個進程池都需要設(shè)置.
listen.backlog = -1
#backlog數(shù),-1表示無限制,由操作系統(tǒng)決定,此行注釋掉就行。backlog含義參考:http://www.3gyou.cc/?p=41
listen.allowed_clients = 127.0.0.1
#允許訪問FastCGI進程的IP,設(shè)置any為不限制IP,如果要設(shè)置其他主機的nginx也能訪問這臺FPM進程,listen處要設(shè)置成本地可被訪問的IP。默認值是any。每個地址是用逗號分隔.如果沒有設(shè)置或者為空,則允許任何服務(wù)器請求連接
listen.owner = www
listen.group = www
listen.mode = 0666
#unix socket設(shè)置選項,如果使用tcp方式訪問,這里注釋即可。
user = www
group = www
#啟動進程的帳戶和組
pm = dynamic #對于專用服務(wù)器,pm可以設(shè)置為static。
#如何控制子進程,選項有static和dynamic。如果選擇static,則由pm.max_children指定固定的子進程數(shù)。如果選擇dynamic,則由下開參數(shù)決定:
pm.max_children #,子進程最大數(shù)
pm.start_servers #,啟動時的進程數(shù)
pm.min_spare_servers #,保證空閑進程數(shù)最小值,如果空閑進程小于此值,則創(chuàng)建新的子進程
pm.max_spare_servers #,保證空閑進程數(shù)最大值,如果空閑進程大于此值,此進行清理
pm.max_requests = 1000
#設(shè)置每個子進程重生之前服務(wù)的請求數(shù).對于可能存在內(nèi)存泄漏的第三方模塊來說是非常有用的.如果設(shè)置為 '0'則一直接受請求.等同于 PHP_FCGI_MAX_REQUESTS環(huán)境變量.默認值: 0.
pm.status_path = /status
#FPM狀態(tài)頁面的網(wǎng)址.如果沒有設(shè)置,則無法訪問狀態(tài)頁面.默認值: none. munin監(jiān)控會使用到
ping.path = /ping
#FPM監(jiān)控頁面的ping網(wǎng)址.如果沒有設(shè)置,則無法訪問ping頁面.該頁面用于外部檢測FPM是否存活并且可以響應(yīng)請求.請注意必須以斜線開頭 (/)。
ping.response = pong
#用于定義ping請求的返回相應(yīng).返回為 HTTP 200的 text/plain格式文本.默認值: pong.
request_terminate_timeout = 0
#設(shè)置單個請求的超時中止時間.該選項可能會對php.ini設(shè)置中的'max_execution_time'因為某些特殊原因沒有中止運行的腳本有用.設(shè)置為 '0'表示 'Off'.當(dāng)經(jīng)常出現(xiàn)502錯誤時可以嘗試更改此選項。
request_slowlog_timeout = 10s
#當(dāng)一個請求該設(shè)置的超時時間后,就會將對應(yīng)的PHP調(diào)用堆棧信息完整寫入到慢日志中.設(shè)置為 '0'表示 'Off'
slowlog = log/$pool.log.slow
#慢請求的記錄日志,配合request_slowlog_timeout使用
rlimit_files = 1024
#設(shè)置文件打開描述符的rlimit限制.默認值:系統(tǒng)定義值默認可打開句柄是1024,可使用 ulimit -n查看,ulimit -n 2048修改。
rlimit_core = 0
#設(shè)置核心rlimit最大限制值.可用值: 'unlimited'、0或者正整數(shù).默認值:系統(tǒng)定義值.
chroot =
#啟動時的Chroot目錄.所定義的目錄需要是絕對路徑.如果沒有設(shè)置,則chroot不被使用.
chdir =
#設(shè)置啟動目錄,啟動時會自動Chdir到該目錄.所定義的目錄需要是絕對路徑.默認值:當(dāng)前目錄,或者/目錄(chroot時)
catch_workers_output = yes
#重定向運行過程中的stdout和stderr到主要的錯誤日志文件中.如果沒有設(shè)置, stdout和 stderr將會根據(jù)FastCGI的規(guī)則被重定向到 /dev/null .默認值:空.
三,常見錯誤及解決辦法整理
1、request_terminate_timeout引起的資源問題
request_terminate_timeout的值如果設(shè)置為0或者過長的時間,可能會引起file_get_contents的資源問題。
如果file_get_contents請求的遠程資源如果反應(yīng)過慢,file_get_contents就會一直卡在那里不會超時。我們知道php.ini里面max_execution_time可以設(shè)置 PHP腳本的最大執(zhí)行時間,但是,在 php-cgi(php-fpm)中,該參數(shù)不會起效。真正能夠控制 PHP腳本最大執(zhí)行時間的是 php-fpm.conf配置文件中的request_terminate_timeout參數(shù)。
request_terminate_timeout默認值為 0秒,也就是說,PHP腳本會一直執(zhí)行下去。這樣,當(dāng)所有的 php-cgi進程都卡在 file_get_contents()函數(shù)時,這臺 Nginx+PHP的 WebServer已經(jīng)無法再處理新的 PHP請求了,Nginx將給用戶返回“502 Bad Gateway”。修改該參數(shù),設(shè)置一個 PHP腳本最大執(zhí)行時間是必要的,但是,治標(biāo)不治本。例如改成 30s,如果發(fā)生file_get_contents()獲取網(wǎng)頁內(nèi)容較慢的情況,這就意味著 150個 php-cgi進程,每秒鐘只能處理 5個請求,WebServer同樣很難避免”502 Bad Gateway”。解決辦法是request_terminate_timeout設(shè)置為10s或者一個合理的值,或者給file_get_contents加一個超時參數(shù)。
復(fù)制代碼代碼如下:
$ctx = stream_context_create(array(
'http' => array(
'timeout' => 10 //設(shè)置一個超時時間,單位為秒
)
));
file_get_contents($str, 0, $ctx);
2,max_requests參數(shù)配置不當(dāng),可能會引起間歇性502錯誤:
復(fù)制代碼代碼如下:
pm.max_requests = 1000
設(shè)置每個子進程重生之前服務(wù)的請求數(shù).對于可能存在內(nèi)存泄漏的第三方模塊來說是非常有用的.如果設(shè)置為 '0′則一直接受請求.等同于 PHP_FCGI_MAX_REQUESTS環(huán)境變量.默認值: 0.
這段配置的意思是,當(dāng)一個 PHP-CGI進程處理的請求數(shù)累積到 500個后,自動重啟該進程。
但是為什么要重啟進程呢?
一般在項目中,我們多多少少都會用到一些 PHP的第三方庫,這些第三方庫經(jīng)常存在內(nèi)存泄漏問題,如果不定期重啟 PHP-CGI進程,勢必造成內(nèi)存使用量不斷增長。因此 PHP-FPM作為 PHP-CGI的管理器,提供了這么一項監(jiān)控功能,對請求達到指定次數(shù)的 PHP-CGI進程進行重啟,保證內(nèi)存使用量不增長。
正是因為這個機制,在高并發(fā)的站點中,經(jīng)常導(dǎo)致 502錯誤,我猜測原因是 PHP-FPM對從 NGINX過來的請求隊列沒處理好。不過我目前用的還是 PHP 5.3.2,不知道在 PHP 5.3.3中是否還存在這個問題。
目前我們的解決方法是,把這個值盡量設(shè)置大些,盡可能減少 PHP-CGI重新 SPAWN的次數(shù),同時也能提高總體性能。在我們自己實際的生產(chǎn)環(huán)境中發(fā)現(xiàn),內(nèi)存泄漏并不明顯,因此我們將這個值設(shè)置得非常大(204800)。大家要根據(jù)自己的實際情況設(shè)置這個值,不能盲目地加大。
話說回來,這套機制目的只為保證 PHP-CGI不過分地占用內(nèi)存,為何不通過檢測內(nèi)存的方式來處理呢?我非常認同高春輝所說的,通過設(shè)置進程的峰值內(nèi)在占用量來重啟 PHP-CGI進程,會是更好的一個解決方案。
3,php-fpm的慢日志,debug及異常排查神器:
request_slowlog_timeout設(shè)置一個超時的參數(shù),slowlog設(shè)置慢日志的存放位置
復(fù)制代碼代碼如下:
tail -f /var/log/www.slow.log
上面的命令即可看到執(zhí)行過慢的php過程。
大家可以看到經(jīng)常出現(xiàn)的網(wǎng)絡(luò)讀取超過、MySQL查詢過慢的問題,根據(jù)提示信息再排查問題就有很明確的方向了。