PHP內核探索:一次請求的開始與結束

PHP開始執行以後會經過兩個主要的階段:

  • 處理請求之前的開始階段
  • 請求之後的結束階段

開始階段有兩個過程:

第一個過程是模塊初始化階段(MINIT), 在整個SAPI生命週期內(例如Apache啓動以後的整個生命週期內或者命令行程序整個執行過程中), 該過程只進行一次。

第二個過程是模塊激活階段(RINIT),該過程發生在請求階段, 例如通過url請求某個頁面,則在每次請求之前都會進行模塊激活(RINIT請求開始)。 例如PHP註冊了一些擴展模塊,則在MINIT階段會回調所有模塊的MINIT函數。 模塊在這個階段可以進行一些初始化工作,例如註冊常量,定義模塊使用的類等等。

模塊在實現時可以通過如下宏來實現這些回調函數:

1 PHP_MINIT_FUNCTION(myphpextension)
2 {
3     // 註冊常量或者類等初始化操作
4     return SUCCESS;
5 }

請求到達之後PHP初始化執行腳本的基本環境,例如創建一個執行環境,包括保存PHP運行過程中變量名稱和值內容的符號表, 以及當前所有的函數以及類等信息的符號表。然後PHP會調用所有模塊的RINIT函數, 在這個階段各個模塊也可以執行一些相關的操作,模塊的RINIT函數和MINIT回調函數類似:

1 PHP_RINIT_FUNCTION(myphpextension)
2 {
3     // 例如記錄請求開始時間
4     // 隨後在請求結束的時候記錄結束時間。這樣我們就能夠記錄下處理請求所花費的時間了
5     return SUCCESS;
6 }

請求處理完後就進入了結束階段,一般腳本執行到末尾或者通過調用exit()或die()函數, PHP都將進入結束階段。和開始階段對應,結束階段也分爲兩個環節,一個在請求結束後停用模塊(RSHUWDOWN,對應RINIT), 一個在SAPI生命週期結束(Web服務器退出或者命令行腳本執行完畢退出)時關閉模塊(MSHUTDOWN,對應MINIT)。

1 PHP_RSHUTDOWN_FUNCTION(myphpextension)
2 {
3     // 例如記錄請求結束時間,並把相應的信息寫入到日至文件中。
4     return SUCCESS;
5 }
發佈了25 篇原創文章 · 獲贊 13 · 訪問量 4萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章