php 中php-fpm工作原理


1.CGI

是服務器與后台語言交互的協議,有了這個協議,開發者可以使用任何語言處理服務器轉發過來的請求,動態地生成內容,

保證了傳遞過來的數據是標准格式的(規定了以什么樣的格式傳哪些數據(URL、查詢字符串、POST數據、HTTP header等等)),方便了開發者。

2.fastCGI

首先, FastCGI會先啟一個 master進程,解析配置文件,初始化執行環境,然后再啟動多個 worker進程。當請求過來時, master會傳遞給一個 worker,然后立即可以接受下一個請求。
這樣就避免了重復的勞動,效率自然是高。
而且當 worker不夠用時, master可以根據配置預先啟動幾個 worker等着。
當然空閑 worker太多時,也會停掉一些,這樣就提高了性能,也節約了資源。這就是 FastCGI的對進程的管理。
 
 
3.php-fpm
master進程只有一個,負責監聽端口,接收來自服務器的請求,而 worker進程則一般有多個(具體數量根據實際需要配置),每個進程內部都嵌入了一個 PHP解釋器
PHP代碼真正執行的地方,下面是我本機上 FPM的進程情況:1個 master進程,2個 worker進程
FPM接收到請求,到處理完畢,其具體的流程如下
1).FPMmaster進程接收到請求。
2).master進程根據配置指派特定的 worker進程進行請求處理,如果沒有可用進程,返回錯誤,這也是我們配合 Nginx遇到 502錯誤比較多的原因。
3).worker進程處理請求,如果超時,返回 504錯誤。

4).請求處理結束,返回結果。

4 php-fpm配置文件

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含義參考:
 
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指定固定的子進程數。如果選擇dynamic,則由下開參數決定:
pm.max_children #,子進程最大數
pm.start_servers #,啟動時的進程數
pm.min_spare_servers #,保證空閑進程數最小值,如果空閑進程小於此值,則創建新的子進程
pm.max_spare_servers #,保證空閑進程數最大值,如果空閑進程大於此值,此進行清理
 
pm.max_requests = 1000
#設置每個子進程重生之前服務的請求數. 對於可能存在內存泄漏的第三方模塊來說是非常有用的. 如果設置為 ’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.
 
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 . 默認值: 空.

 

參考文件:

https://www.jianshu.com/p/da152c6fdfa6

https://www.cnblogs.com/ahaii/p/5776809.html


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM