Linux下PHP-fpm配置

轉自:http://www.jb51.net/article/42716.htm

一卿泽、約定幾個目錄

/usr/local/php/sbin/php-fpm

/usr/local/php/etc/php-fpm.conf

/usr/local/php/etc/php.ini

二亡容、php-fpm的啟動參數(shù)

#測試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

#關閉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ù)詳解

pid = run/php-fpm.pid

#pid設置锦秒,默認在安裝目錄中的var/run/php-fpm.pid听盖,建議開啟

error_log = log/php-fpm.log

#錯誤日志卓起,默認在安裝目錄中的var/log/php-fpm.log

log_level = notice

#錯誤級別. 可用級別為: alert(必須立即處理), error(錯誤情況), warning(警告情況), notice(一般重要信息), debug(調試信息). 默認: notice.

emergency_restart_threshold = 60

emergency_restart_interval = 60s

#表示在emergency_restart_interval所設值內出現(xiàn)SIGSEGV或者SIGBUS錯誤的php-cgi進程數(shù)如果超過 emergency_restart_threshold個兴蒸,php-fpm就會優(yōu)雅重啟。這兩個選項一般保持默認值裳瘪。

process_control_timeout = 0

#設置子進程接受主進程復用信號的超時時間. 可用單位: s(秒), m(分), h(小時), 或者 d(天) 默認單位: s(秒). 默認值: 0.

daemonize = yes

#后臺執(zhí)行fpm,默認值為yes土浸,如果為了調試可以改為no。在FPM中彭羹,可以使用不同的設置來運行多個進程池黄伊。 這些設置可以針對每個進程池單獨設置。

listen = 127.0.0.1:9000

#fpm監(jiān)聽端口派殷,即nginx中php處理的地址还最,一般默認值即可≌毕В可用格式為: 'ip:port', 'port', '/path/to/unix/socket'. 每個進程池都需要設置.

listen.backlog = -1

#backlog數(shù)拓轻,-1表示無限制,由操作系統(tǒng)決定经伙,此行注釋掉就行扶叉。backlog含義參考:http://www.3gyou.cc/?p=41

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指定固定的子進程數(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ù). 對于可能存在內存泄漏的第三方模塊來說是非常有用的. 如果設置為 '0' 則一直接受請求. 等同于 PHP_FCGI_MAX_REQUESTS 環(huán)境變量. 默認值: 0.

pm.status_path = /status

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

ping.path = /ping

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

ping.response = pong

#用于定義ping請求的返回相應. 返回為 HTTP 200 的 text/plain 格式文本. 默認值: pong.

request_terminate_timeout = 0

#設置單個請求的超時中止時間. 該選項可能會對php.ini設置中的'max_execution_time'因為某些特殊原因沒有中止運行的腳本有用. 設置為 '0' 表示 'Off'.當經常出現(xiàn)502錯誤時可以嘗試更改此選項。

request_slowlog_timeout = 10s

#當一個請求該設置的超時時間后交排,就會將對應的PHP調用堆棧信息完整寫入到慢日志中. 設置為 '0' 表示 'Off'

slowlog = log/$pool.log.slow

#慢請求的記錄日志,配合request_slowlog_timeout使用

rlimit_files = 1024

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

rlimit_core = 0

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

chroot =

#啟動時的Chroot目錄. 所定義的目錄需要是絕對路徑. 如果沒有設置, 則chroot不被使用.

chdir =

#設置啟動目錄,啟動時會自動Chdir到該目錄. 所定義的目錄需要是絕對路徑. 默認值: 當前目錄架专,或者/目錄(chroot時)

catch_workers_output = yes

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

四同窘、常見錯誤及解決辦法整理

1、request_terminate_timeout引起的資源問題

request_terminate_timeout的值如果設置為0或者過長的時間部脚,可能會引起file_get_contents的資源問題想邦。

如果file_get_contents請求的遠程資源如果反應過慢,file_get_contents就會一直卡在那里不會超時委刘。我們知道php.ini里面max_execution_time 可以設置 PHP 腳本的最大執(zhí)行時間丧没,但是,在 php-cgi(php-fpm)中钱雷,該參數(shù)不會起效骂铁。真正能夠控制 PHP 腳本最大執(zhí)行時間的是 php-fpm.conf配置文件中的request_terminate_timeout參數(shù)。

request_terminate_timeout默認值為 0 秒罩抗,也就是說,PHP 腳本會一直執(zhí)行下去灿椅。這樣套蒂,當所有的 php-cgi進程都卡在 file_get_contents() 函數(shù)時,這臺 Nginx+PHP 的 WebServer 已經無法再處理新的 PHP請求了茫蛹,Nginx 將給用戶返回“502 Bad Gateway”操刀。修改該參數(shù),設置一個 PHP腳本最大執(zhí)行時間是必要的婴洼,但是骨坑,治標不治本。例如改成 30s柬采,如果發(fā)生 file_get_contents()獲取網(wǎng)頁內容較慢的情況欢唾,這就意味著 150 個 php-cgi 進程,每秒鐘只能處理 5 個請求粉捻,WebServer 同樣很難避免”502BadGateway”礁遣。解決辦法是request_terminate_timeout設置為10s或者一個合理的值,或者給file_get_contents加一個超時參數(shù)肩刃。

代碼如下:

$ctx = stream_context_create(array(

'http' => array(

'timeout' => 10??? //設置一個超時時間祟霍,單位為秒

)

));

file_get_contents($str, 0, $ctx);

2杏头、max_requests參數(shù)配置不當,可能會引起間歇性502錯誤:

代碼如下:

pm.max_requests = 1000

設置每個子進程重生之前服務的請求數(shù). 對于可能存在內存泄漏的第三方模塊來說是非常有用的. 如果設置為 '0′ 則一直接受請求. 等同于 PHP_FCGI_MAX_REQUESTS 環(huán)境變量. 默認值: 0.這段配置的意思是沸呐,當一個 PHP-CGI 進程處理的請求數(shù)累積到 500 個后醇王,自動重啟該進程。

但是為什么要重啟進程呢崭添?

一般在項目中厦画,我們多多少少都會用到一些 PHP 的第三方庫,這些第三方庫經常存在內存泄漏問題滥朱,如果不定期重啟 PHP-CGI 進程根暑,勢必造成內存使用量不斷增長。因此 PHP-FPM 作為PHP-CGI 的管理器徙邻,提供了這么一項監(jiān)控功能排嫌,對請求達到指定次數(shù)的 PHP-CGI 進程進行重啟,保證內存使用量不增長缰犁。

正是因為這個機制淳地,在高并發(fā)的站點中,經常導致 502 錯誤帅容,我猜測原因是 PHP-FPM 對從NGINX 過來的請求隊列沒處理好颇象。不過我目前用的還是 PHP 5.3.2,不知道在 PHP 5.3.3 中是否還存在這個問題并徘。

目前我們的解決方法是遣钳,把這個值盡量設置大些,盡可能減少 PHP-CGI 重新 SPAWN 的次數(shù)麦乞,同時也能提高總體性能蕴茴。在我們自己實際的生產環(huán)境中發(fā)現(xiàn),內存泄漏并不明顯姐直,因此我們將這個值設置得非常大(204800)倦淀。大家要根據(jù)自己的實際情況設置這個值,不能盲目地加大声畏。

話說回來撞叽,這套機制目的只為保證 PHP-CGI 不過分地占用內存,為何不通過檢測內存的方式來處理呢插龄?我非常認同高春輝所說的愿棋,通過設置進程的峰值內在占用量來重啟 PHP-CGI 進程,會是更好的一個解決方案辫狼。

3初斑、php-fpm的慢日志,debug及異常排查神器:

request_slowlog_timeout設置一個超時的參數(shù)膨处,slowlog設置慢日志的存放位置

代碼如下:

tail -f /var/log/www.slow.log

上面的命令即可看到執(zhí)行過慢的php過程见秤。

大家可以看到經常出現(xiàn)的網(wǎng)絡讀取超過砂竖、Mysql查詢過慢的問題,根據(jù)提示信息再排查問題就有很明確的方向了鹃答。

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
  • 序言:七十年代末乎澄,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子测摔,更是在濱河造成了極大的恐慌置济,老刑警劉巖,帶你破解...
    沈念sama閱讀 217,509評論 6 504
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件锋八,死亡現(xiàn)場離奇詭異浙于,居然都是意外死亡,警方通過查閱死者的電腦和手機挟纱,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,806評論 3 394
  • 文/潘曉璐 我一進店門羞酗,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人紊服,你說我怎么就攤上這事檀轨。” “怎么了欺嗤?”我有些...
    開封第一講書人閱讀 163,875評論 0 354
  • 文/不壞的土叔 我叫張陵参萄,是天一觀的道長。 經常有香客問我煎饼,道長讹挎,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,441評論 1 293
  • 正文 為了忘掉前任腺占,我火速辦了婚禮淤袜,結果婚禮上,老公的妹妹穿的比我還像新娘衰伯。我一直安慰自己,他們只是感情好积蔚,可當我...
    茶點故事閱讀 67,488評論 6 392
  • 文/花漫 我一把揭開白布意鲸。 她就那樣靜靜地躺著,像睡著了一般尽爆。 火紅的嫁衣襯著肌膚如雪怎顾。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,365評論 1 302
  • 那天漱贱,我揣著相機與錄音槐雾,去河邊找鬼。 笑死幅狮,一個胖子當著我的面吹牛募强,可吹牛的內容都是我干的株灸。 我是一名探鬼主播,決...
    沈念sama閱讀 40,190評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼擎值,長吁一口氣:“原來是場噩夢啊……” “哼慌烧!你這毒婦竟也來了?” 一聲冷哼從身側響起鸠儿,我...
    開封第一講書人閱讀 39,062評論 0 276
  • 序言:老撾萬榮一對情侶失蹤屹蚊,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后进每,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體汹粤,經...
    沈念sama閱讀 45,500評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 37,706評論 3 335
  • 正文 我和宋清朗相戀三年田晚,在試婚紗的時候發(fā)現(xiàn)自己被綠了嘱兼。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 39,834評論 1 347
  • 序言:一個原本活蹦亂跳的男人離奇死亡肉瓦,死狀恐怖遭京,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情泞莉,我是刑警寧澤哪雕,帶...
    沈念sama閱讀 35,559評論 5 345
  • 正文 年R本政府宣布,位于F島的核電站鲫趁,受9級特大地震影響斯嚎,放射性物質發(fā)生泄漏。R本人自食惡果不足惜挨厚,卻給世界環(huán)境...
    茶點故事閱讀 41,167評論 3 328
  • 文/蒙蒙 一堡僻、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧疫剃,春花似錦钉疫、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,779評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至壤躲,卻和暖如春城菊,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背碉克。 一陣腳步聲響...
    開封第一講書人閱讀 32,912評論 1 269
  • 我被黑心中介騙來泰國打工凌唬, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人漏麦。 一個月前我還...
    沈念sama閱讀 47,958評論 2 370
  • 正文 我出身青樓客税,卻偏偏與公主長得像况褪,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子霎挟,可洞房花燭夜當晚...
    茶點故事閱讀 44,779評論 2 354

推薦閱讀更多精彩內容