nginx + php-fpm,連線數一多會發生,502 Bad Gateway 或 504 Gateway Time-out 等問題。
502 Bad Gateway:nginx 連不到 php-fpm。可以增加 php-fpm 連線數量。或將 nginx 連 php-fpm 等待連接的時間設長一點(fastcgi_connect_timeout)。
504 Gateway Time-out:php-fpm 執行時間,超過 nginx 允許的接收時間。可以將 nginx 接收時間設長一點(fastcgi_read_timeout)。
影響連線數限制的設定有三個:linux 系統的限制、nginx 的限制、php-fpm 的限制。
 
php-fpm的安裝目錄
/usr/local/php/php
 
php 與 php-fpm設定位置
/usr/local/php/etc/php.ini
/usr/local/php/etc/php-fpm.conf


 
 
 
 
[global]
pid = /usr/local/php/var/run/php-fpm.pid
error_log = /usr/local/php/var/log/php-fpm.log
log_level = notice
 
[www]
listen = /tmp/php-cgi.sock
listen.backlog = -1
listen.allowed_clients = 127.0.0.1
listen.owner = www
listen.group = www
listen.mode = 0666
user = www
group = www
pm = dynamic
pm.max_children = 20
pm.start_servers = 10
pm.min_spare_servers = 10
pm.max_spare_servers = 20
request_terminate_timeout = 100
request_slowlog_timeout = 0
slowlog = var/log/slow.log
 
php-fpm配置詳解
pid = /usr/local/php/var/run/php-fpm.pid
#pid設置,一定要開啟。

error_log = /usr/local/php/var/log/php-fpm.log
#錯誤日誌

log_level = notice
#錯誤級別. 上面的php-fpm.log紀錄的登記。可用級別為: alert(必須立即處理), error(錯誤情況), warning(警告情況), notice(一般重要信息), debug(調試信息). 預設: notice.

emergency_restart_threshold = 60
emergency_restart_interval = 60s
#表示在emergency_restart_interval所設值內出現SIGSEGV或者SIGBUS錯誤的php-cgiprogress數如果超過 emergency_restart_threshold個,php-fpm就會重啟。這兩個選項一般保持預設值。0 表示 ‘關閉該功能’. 預設值: 0 (關閉)

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

daemonize = yes
#後台執行fpm,預設值為yes,如果為了調試可以改為no。在FPM中,可以使用不同的設置來運行多個progress池。 這些設置可以針對每個progress池單獨設置。

 
 
 
 
listen = 127.0.0.1:9000
#fpm監聽端口,即nginx中php處理的地址,一般預設值即可。可用格式為: ‘ip:port’, ‘port’, ‘/path/to/unix/socket’. 每個progress池都需要設置。如果nginx和php在不同的機器上,分佈式處理,就設置ip這裡就可以了。

listen.backlog = -1
#backlog數,設置 listen 的半連接隊列長度,-1表示無限制,由操作系統決定。

listen.allowed_clients = 127.0.0.1
#允許訪問FastCGIprogress的IP白名單,設置any為不限制IP,如果要設置其他主機的nginx也能訪問這台FPMprogress,listen處要設置成本地可被訪問的IP。預設值是any。每個地址是用逗號分隔. 如果沒有設置或者為空,則允許任何服務器請求連接。

listen.owner = www
listen.group = www
listen.mode = 0666
#unix socket設置選項,如果使用tcp方式訪問,這裡註釋即可。

user = www
group = www
#啟動progress的用戶和用戶組,FPM progress運行的Unix用戶, 必須要設置。用戶組,如果沒有設置,則預設用戶的組被使用。

pm = dynamic
#php-fpmprogress啟動模式,pm可以設置為static和dynamic和ondemand
#如果選擇static,則progress數就數固定的,由pm.max_children指定固定的子progress數。
#如果選擇dynamic,則progress數是動態變化的,由以下參數決定:
pm.max_children = 50 #子progress最大數
pm.start_servers = 2 #啟動時的progress數,預設值為: min_spare_servers + (max_spare_servers – min_spare_servers) / 2
pm.min_spare_servers = 1 #保證空閒progress數最小值,如果空閒progress小於此值,則創建新的子progress
pm.max_spare_servers = 3 #,保證空閒progress數最大值,如果空閒progress大於此值,此進行清理

pm.max_requests = 500
#設置每個子progress重生之前服務的請求數. 對於可能存在內存洩漏的第三方模塊來說是非常有用的. 如果設置為 ‘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.

access.log = log/$pool.access.log
#每一個請求的訪問日誌,預設是關閉的。

access.format = “%R – %u %t \"%m %r%Q%q\" %s %f %{mili}d %{kilo}M %C%%"
#設定訪問日誌的格式。

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

request_slowlog_timeout = 10s
#當一個請求該設置的超時時間後,就會將對應的PHP調用堆棧信息完整寫入到慢日誌中. 設置為 ‘0’ 表示 ‘Off’

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

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 . 預設值: 空
ERIC2883

Tags: , , ,