PHP底層工作原理

最近搭建服務器,突然感覺lamp之間到底是怎麼工作的,或者是怎麼聯繫起來?平時只是寫程序,重來沒有思考過他們之間的工作原理:

PHP底層工作原理

wps_clip_image-29471

圖1 php結構

從圖上可以看出,php從下到上是一個4層體系

①Zend引擎

Zend整體用純c實現,是php的內核部分,它將php代碼翻譯(詞法、語法解析等一系列編譯過程)爲可執行opcode的處理並實現相應的處理方法、實現了基本的數據結構(如hashtable、oo)、內存分配及管理、提供了相應的api方法供外部調用,是一切的核心,所有的外圍功能均圍繞zend實現。

②Extensions

圍繞着zend引擎,extensions通過組件式的方式提供各種基礎服務,我們常見的各種內置函數(如array系列)、標準庫等都是通過extension來實現,用戶也可以根據需要實現自己的extension以達到功能擴展、性能優化等目的(如貼吧正在使用的php中間層、富文本解析就是extension的典型應用)。

③Sapi

Sapi全稱是Server Application Programming Interface,也就是服務端應用編程接口,sapi通過一系列鉤子函數,使得php可以和外圍交互數據,這是php非常優雅和成功的一個設計,通過sapi成功的將php本身和上層應用解耦隔離,php可以不再考慮如何針對不同應用進行兼容,而應用本身也可以針對自己的特點實現不同的處理方式。後面將在sapi章節中介紹

④上層應用

這就是我們平時編寫的php程序,通過不同的sapi方式得到各種各樣的應用模式,如通過webserver實現web應用、在命令行下以腳本方式運行等等。

構架思想:

引擎(Zend)+組件(ext)的模式降低內部耦合

中間層(sapi)隔絕web server和php

**************************************************************************

如果php是一輛車,那麼

車的框架就是php本身

Zend是車的引擎(發動機)

Ext下面的各種組件就是車的輪子

Sapi可以看做是公路,車可以跑在不同類型的公路上

而一次php程序的執行就是汽車跑在公路上。

因此,我們需要:性能優異的引擎+合適的車輪+正確的跑道

Apache和php的關係

Apache對於php的解析,就是通過衆多Module中的php Module來完成的。

wps_clip_image-31721

把php最終集成到Apache系統中,還需要對Apache進行一些必要的設置。這裏,我們就以php的mod_php5 SAPI運行模式爲例進行講解,至於SAPI這個概念後面我們還會詳細講解。

假定我們安裝的版本是Apache2 和 Php5,那麼需要編輯Apache的主配置文件http.conf,在其中加入下面的幾行內容:

Unix/Linux環境下:

LoadModule php5_module modules/mod_php5.so

AddType application/x-httpd-php .php

注:其中modules/mod_php5.so 是X系統環境下mod_php5.so文件的安裝位置。

Windows環境下:

LoadModule php5_module d:/php/php5apache2.dll

AddType application/x-httpd-php .php

注:其中d:/php/php5apache2.dll 是在Windows環境下php5apache2.dll文件的安裝位置。

這兩項配置就是告訴Apache Server,以後收到的Url用戶請求,凡是以php作爲後綴,就需要調用php5_module模塊(mod_php5.so/ php5apache2.dll)進行處理。

Apache的生命週期

wps_clip_image-8490

Apach的請求處理流程

wps_clip_image-17917

Apache請求處理循環詳解 
    Apache請求處理循環的11個階段都做了哪些事情呢?

1、Post-Read-Request階段

    在正常請求處理流程中,這是模塊可以插入鉤子的第一個階段。對於那些想很早進入處理請求的模塊來說,這個階段可以被利用。

    2、URI Translation階段 
    Apache在本階段的主要工作:將請求的URL映射到本地文件系統。模塊可以在這階段插入鉤子,執行自己的映射邏輯。mod_alias就是利用這個階段工作的。

    3、Header Parsing階段 
    Apache在本階段的主要工作:檢查請求的頭部。由於模塊可以在請求處理流程的任何一個點上執行檢查請求頭部的任務,因此這個鉤子很少被使用。mod_setenvif就是利用這個階段工作的。

    4、Access Control階段 
    Apache在本階段的主要工作:根據配置文件檢查是否允許訪問請求的資源。Apache的標準邏輯實現了允許和拒絕指令。mod_authz_host就是利用這個階段工作的。

    5、Authentication階段 
     Apache在本階段的主要工作:按照配置文件設定的策略對用戶進行認證,並設定用戶名區域。模塊可以在這階段插入鉤子,實現一個認證方法。

    6、Authorization階段 
    Apache在本階段的主要工作:根據配置文件檢查是否允許認證過的用戶執行請求的操作。模塊可以在這階段插入鉤子,實現一個用戶權限管理的方法。

    7、MIME Type Checking階段 
    Apache在本階段的主要工作:根據請求資源的MIME類型的相關規則,判定將要使用的內容處理函數。標準模塊mod_negotiation和mod_mime實現了這個鉤子。

    8、FixUp階段 
    這是一個通用的階段,允許模塊在內容生成器之前,運行任何必要的處理流程。和Post_Read_Request類似,這是一個能夠捕獲任何信息的鉤子,也是最常使用的鉤子。

    9、Response階段 
    Apache在本階段的主要工作:生成返回客戶端的內容,負責給客戶端發送一個恰當的回覆。這個階段是整個處理流程的核心部分。

    10、Logging階段 
    Apache在本階段的主要工作:在回覆已經發送給客戶端之後記錄事務。模塊可能修改或者替換Apache的標準日誌記錄。

11、CleanUp階段 
    Apache在本階段的主要工作:清理本次請求事務處理完成之後遺留的環境,比如文件、目錄的處理或者Socket的關閉等等,這是Apache一次請求處理的最後一個階段。

LAMP架構:

wps_clip_image-24435

從下往上四層:

①liunx 屬於操作系統的底層

②apache服務器,屬於次服務器,溝通linux和PHP

③php:屬於服務端編程語言,通過php_module 模塊 和apache關聯

    ④mysql和其他web服務:屬於應用服務,通過PHP的Extensions外 掛模塊和mysql關聯

Android系統架構圖

lamp和安卓的架構圖比較一下,貌似和lamp架構有點相似,本人不懂安卓,只是感覺上有點相似,高手可以指出區別,小弟在此不勝感謝

wps_clip_image-27187

從上往下:

安卓架構--------------說明--------LAMP架構

1.應用程序 --------具體應用--------web應用

2.應用程序框架 ----java-------------PHP語言和庫

3.系統運行庫 :----虛擬機---------WEB服務器

⒋Linux 內核 :---操作系統-------lamp架構中的L

lamp和電腦內部的關係

CPU是工廠,硬盤是大倉庫,內存是正規中轉中心,虛擬內存是臨時中轉中心 

 

Php語言由zend編譯成機器語言,操作cpu

對數據庫的操作屬於I/O操作,屬於機械運動,也就是說一個網站的瓶頸再去對硬盤的讀寫造成的,解決辦法就是減少i/o操作次數,使用緩衝技術,就是在數據的操作放在mencache裏面,達到一定數量級的時候在一次性寫入數據庫,mencache屬於key--value關係

而非關係型數據也是基於這個理念建設的,也是屬於key--value關係

 

頻繁讀操作------放在mencache裏面

讀多寫少----放在nosql裏面------讀取功能很強大!

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章