婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > PHP7內核CGI與FastCGI詳解

PHP7內核CGI與FastCGI詳解

熱門標簽:海南人工外呼系統有效果嗎 保定crm外呼系統運營商 九江外呼系統 智能電話機器人排名前十名南京 抖音有個地圖標注是什么意思 地下城堡2圖九地圖標注 七魚外呼系統停用嗎 西區企業怎么做地圖標注入駐 阿里云400電話申請加工單

CGI:是 Web Server 與 Web Application 之間數據交換的一種協議。
FastCGI:同 CGI,是一種通信協議,但比 CGI 在效率上做了一些優化。

PHP-CGI:是 PHP (Web Application)對 Web Server 提供的 CGI 協議的接口程序。

PHP-FPM:是 PHP(Web Application)對 Web Server 提供的 FastCGI 協議的接口程序,額外還提供了相對智能一些任務管理

CGI工作流程

1.如果客戶端請求的是 index.html,那么Web Server會去文件系統中找到這個文件,發送給瀏覽器,這里分發的是靜態數據。

2.當Web Server收到 index.php 這個請求后,會啟動對應的 CGI 程序,這里就是PHP的解析器。接下來PHP解析器會解析php.ini文件,初始化執行環境,然后處理請求,再以規定CGI規定的格式返回處理后的結果,退出進程,Web server再把結果返回給瀏覽器。

FastCGI工作流程

1.如果客戶端請求的是 index.html,那么Web Server會去文件系統中找到這個文件,發送給瀏覽器,這里分發的是靜態數據。

2.當Web Server收到 index.php 這個請求后,FastCGI程序(FastCGI在啟動時就初始化執行執行環境,每個CGI進程池各個CGI進程共享執行環境)在CGI進程池中選擇一個CGI進程處理請求,再以規定CGI規定的格式返回處理后的結果,繼續等待下一個請求。

PHP-FPM基本實現

1.PHP-FPM的實現就是創建一個master進程,在master進程中創建worker pool并讓其監聽socket,然后fork出多個子進程(work),這些子進程各自accept請求,子進程的處理非常簡單,它在啟動后阻塞在accept上,有請求到達后開始讀取請求數據,讀取完成后開始處理然后再返回,在這期間是不會接收其它請求的,也就是說PHP-FPM的子進程同時只能響應一個請求,只有把這個請求處理完成后才會accept下一個請求

2.PHP-FPM的master進程與worker進程之間不會直接進行通信,master通過共享內存獲取worker進程的信息,比如worker進程當前狀態、已處理請求數等,當master進程要殺掉一個worker進程時則通過發送信號的方式通知worker進程。

3.PHP-FPM可以同時監聽多個端口,每個端口對應一個worker pool,而每個pool下對應多個worker進程

Worker工作流程

1.等待請求: worker進程阻塞在fcgi_accept_request()等待請求;

2.解析請求: fastcgi請求到達后被worker接收,然后開始接收并解析請求數據,直到request數據完全到達;

3.請求初始化: 執行php_request_startup(),此階段會調用每個擴展的:PHP_RINIT_FUNCTION();

4.編譯、執行: 由php_execute_script()完成PHP腳本的編譯、執行;

5.關閉請求: 請求完成后執行php_request_shutdown(),此階段會調用每個擴展的:PHP_RSHUTDOWN_FUNCTION(),然后進入步驟(1)等待下一個請求。

Master進程管理

1.static: 這種方式比較簡單,在啟動時master按照pm.max_children配置fork出相應數量的worker進程,即worker進程數是固定不變的

2.dynamic: 動態進程管理,首先在fpm啟動時按照pm.start_servers初始化一定數量的worker,運行期間如果master發現空閑worker數低于pm.min_spare_servers配置數(表示請求比較多,worker處理不過來了)則會fork worker進程,但總的worker數不能超過pm.max_children,如果master發現空閑worker數超過了pm.max_spare_servers(表示閑著的worker太多了)則會殺掉一些worker,避免占用過多資源,master通過這4個值來控制worker數

3.ondemand: 這種方式一般很少用,在啟動時不分配worker進程,等到有請求了后再通知master進程fork worker進程,總的worker數不超過pm.max_children,處理完成后worker進程不會立即退出,當空閑時間超過pm.process_idle_timeout后再退出

PHP-FPM事件管理器

1.sp[1]管道可讀事件:這個事件是master用于處理信號的

2.fpm_pctl_perform_idle_server_maintenance_heartbeat():這是進程管理實現的主要事件,master啟動了一個定時器,每隔1s觸發一次,主要用于dynamic、ondemand模式下的worker管理,master會定時檢查各worker pool的worker進程數,通過此定時器實現worker數量的控制

3.fpm_pctl_heartbeat():這個事件是用于限制worker處理單個請求最大耗時的,php-fpm.conf中有一個request_terminate_timeout的配置項,如果worker處理一個請求的總時長超過了這個值那么master將會向此worker進程發送kill -TERM信號殺掉worker進程,此配置單位為秒,默認值為0表示關閉此機制

4.fpm_pctl_on_socket_accept():ondemand模式下master監聽的新請求到達的事件,因為ondemand模式下fpm啟動時是不會預創建worker的,有請求時才會生成子進程,所以請求到達時需要通知master進程

您可能感興趣的文章:
  • Windows 2008 R2 用PHP Manager for IIS 配置PHP(FastCGI)環境
  • PHP(FastCGI)在Nginx的alias下出現404錯誤的解決方法
  • 在PHP中使用FastCGI解析漏洞及修復方案
  • php以fastCGI的方式運行時文件系統權限問題及解決方法
  • PHP 5.3和PHP 5.4出現FastCGI Error解決方法

標簽:十堰 昭通 甘肅 韶關 涼山 九江 遼陽 梅河口

巨人網絡通訊聲明:本文標題《PHP7內核CGI與FastCGI詳解》,本文關鍵詞  PHP7,內核,CGI,與,FastCGI,詳解,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《PHP7內核CGI與FastCGI詳解》相關的同類信息!
  • 本頁收集關于PHP7內核CGI與FastCGI詳解的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 吉林省| 翁牛特旗| 余姚市| 都兰县| 新巴尔虎右旗| 临海市| 南乐县| 安国市| 衡东县| 柳州市| 涿鹿县| 米脂县| 腾冲县| 盐城市| 广南县| 邵武市| 拉孜县| 宜阳县| 阿合奇县| 丰县| 九龙县| 吉木萨尔县| 郁南县| 宜都市| 靖州| 玛曲县| 洱源县| 丹凤县| 田林县| 德州市| 同心县| 海安县| 六安市| 承德市| 株洲市| 肥城市| 应城市| 紫阳县| 祁阳县| 泰州市| 龙陵县|