1.CGI
是服務器與后台語言交互的協議,有了這個協議,開發者可以使用任何語言處理服務器轉發過來的請求,動態地生成內容,
保證了傳遞過來的數據是標准格式
的(規定了以什么樣的格式傳哪些數據(URL、查詢字符串、POST數據、HTTP header等等
)),方便了開發者。
2.fastCGI
首先,
這樣就避免了重復的勞動,效率自然是高。
而且當
當然空閑
FastCGI
會先啟一個
master進程
,解析配置文件,初始化執行環境,然后再啟動多個
worker進程
。當請求過來時,
master
會傳遞給一個
worker
,然后立即可以接受下一個請求。
這樣就避免了重復的勞動,效率自然是高。
而且當
worker
不夠用時,
master
可以根據配置預先啟動幾個
worker
等着。
當然空閑
worker
太多時,也會停掉一些,這樣就提高了性能,也節約了資源。這就是
FastCGI
的對進程的管理。
master進程
只有一個,負責監聽端口,接收來自服務器的請求,而
worker進程
則一般有多個(具體數量根據實際需要配置),每個進程內部都嵌入了一個
PHP解釋器
,
是
PHP代碼
真正執行的地方,下面是我本機上
FPM
的進程情況:1個
master進程
,2個
worker進程
。
從
FPM
接收到請求,到處理完畢,其具體的流程如下
1).FPM
的
master進程
接收到請求。
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 . 默認值: 空.
參考文件: