php-fpm報錯

coyan發表於2021-09-09

[root@centOS1 etc]# vim php-fpm.conf

error_log = log/php-fpm.log
emergency_restart_threshold = 10
emergency_restart_interval = 1m
process_control_timeout = 5s
pm.start_servers = 20
pm.min_spare_servers = 5
pm.max_spare_servers = 35
pm.max_children = 35

報錯:找不到pid檔案!

[root@centOS1 php-5.3.6]# service php-fpm restart
Gracefully shutting down php-fpm warning, no pid file found - php-fpm is not running ?
Starting php-fpm [08-Jun-2014 23:31:44] ERROR: [/opt/php/etc/php-fpm.conf:27] unknown entry 'pm.start_servers'
[08-Jun-2014 23:31:44] ERROR: failed to load configuration file '/opt/php/etc/php-fpm.conf'
 failed


解決:

出現上面問題的原因是,我在修改這個配置檔案的時候,由於壞習慣的問題,從文件中直接複製到配置檔案中,正確的做法是:在原配置檔案中的原位置處根據文件修改引數,不要一次性為了圖方便而直接粘上去


php-fpm是什麼

全稱是php fastcgi process manager即php fastcgi程式管理器,相比fastcgi靜態的喚起cgi,fpm能根據訪問的壓力動態的喚起cgi程式和銷燬以到達動態的調整cgi數量,這樣可以有效的使用記憶體。除此之外還有其它的一些優點,比如,fpm還可以平滑的過載php配置;由於fpm是使用Unix-Socket來和伺服器通訊,所以也不用再配置cgi埠;fpm有更好的狀態輸出和slowlog日誌,502的時候能給出更多的錯誤細節。


php5.3自帶php-fpm
/usr/local/php/etc/php-fpm.conf
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所設值內出現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表示無限制,由作業系統決定,此行註釋掉就行。backlog含義參考:

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
如何控制子程式,選項有static和dynamic。
如果選擇static,則由pm.max_children指定固定的子程式數。
如果選擇dynamic,則由下開引數決定:
pm.max_children ,子程式最大數
pm.start_servers ,啟動時的程式數
pm.min_spare_servers ,保證空閒程式數最小值,如果空閒程式小於此值,則建立新的子程式
pm.max_spare_servers ,保證空閒程式數最大值,如果空閒程式大於此值,此進行清理
對於專用伺服器,pm可以設定為static。

pm.max_requests = 1000
設定每個子程式重生之前服務的請求數. 對於可能存在記憶體洩漏的第三方模組來說是非常有用的. 如果設定為 '0′ 則一直接受請求. 等同於 PHP_FCGI_MAX_REQUESTS 環境變數. 預設值: 0.

pm.status_path = /status
FPM狀態頁面的網址. 如果沒有設定, 則無法訪問狀態頁面. 預設值: none.

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


來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/2236/viewspace-2809444/,如需轉載,請註明出處,否則將追究法律責任。