<output id="r87xx"></output>
    1. 
      
      <mark id="r87xx"><thead id="r87xx"><input id="r87xx"></input></thead></mark>
        •   

               當(dāng)前位置:首頁>軟件介紹>深度探討PHP之性能 查詢:
               
          深度探討PHP之性能

          關(guān)于PHP,很多人的直觀感覺是PHP是一種靈活的腳本語言,庫類豐富,使用簡單,安全,非常適合WEB開發(fā),但性能低下。PHP的性能是否真的就 如同大家的感覺一樣的差呢?本文就是圍繞這么一個話題來進(jìn)行探討的。從源碼、應(yīng)用場景、基準(zhǔn)性能、對比分析等幾個方面深入分析PHP之性能問題,并通過真 實的數(shù)據(jù)來說話。

           

          2.從原理分析PHP性能

           

          從原理分析PHP的性能,主要從以下幾個方面:內(nèi)存管理、變量、函數(shù)、運行機(jī)制來進(jìn)行分析。

           

          2.1內(nèi)存管理

           

          類似Nginx的內(nèi)存管理方式,PHP在內(nèi)部也是基于內(nèi)存池,并且引入內(nèi)存池的生命周期概念。在內(nèi)存池方面,PHP對PHP腳本和擴(kuò)展的所有內(nèi)存相關(guān) 操作都進(jìn)行了托管。對大內(nèi)存和小內(nèi)存的管理采用了不同的實現(xiàn)方式和優(yōu)化,具體可以參考以下文檔: /internals/zend_mm。在內(nèi)存分配和回收的生命周期內(nèi),PHP采用一次初始化申請+動態(tài)擴(kuò)容+內(nèi)存標(biāo)識回收機(jī)制,并且在每次請求結(jié)束后直 接對內(nèi)存池進(jìn)行重新mask。

           

          2.2變量

           

          總所周知,PHP是一種弱變量類型的語言,所以在PHP內(nèi)部,所有的PHP變量都對應(yīng)成一種類型Zval,

          在變量方面,PHP做了大量的優(yōu)化工作,比如說Reference counting和copy on writer機(jī)制。這樣能夠保證內(nèi)存使用上的優(yōu)化,并且減少內(nèi)存拷貝次數(shù)(請參考)。在數(shù)組方面,PHP內(nèi)部采用高效的hashtable來實現(xiàn)。

           

          2.3函數(shù)

           

          在PHP內(nèi)部,所有的PHP函數(shù)都回轉(zhuǎn)化成內(nèi)部的一個函數(shù)指針。比如說擴(kuò)展中函數(shù)

           

          ZEND_FUNCTION ( my_function );//類似function my_function(){}

           

          在內(nèi)部展開后就會是一個函數(shù)

           

          void zif_my_function ( INTERNAL_FUNCTION_PARAMETERS );

           

          void zif_my_function(

           

          int ht,

           

          zval * return_value,

           

          zval * this_ptr,

           

          int return_value_used,

           

          zend_executor_globals * executor_globals

           

          );

           

          從這個角度來看,PHP函數(shù)在內(nèi)部也是對應(yīng)一個函數(shù)指針。

           

          2.4運行機(jī)制

           

          在話說PHP性能的時候,很多人都會說“C/C++是編譯型,JAVA是半編譯型,PHP是解釋型”。也就是說PHP是先動態(tài)解析再代碼運行的,所以從這個角度來看,PHP性能必然很差。

           

          的確,從PHP腳本運行來輸出,的確是一個動態(tài)解析再代碼運行的過程。具體來說,PHP腳本的運行機(jī)制如下圖所示:

           

          PHP的運行階段也分成三個階段:

           

          Parse。語法分析階段。

           

          Compile。編譯產(chǎn)出opcode中間碼。

           

          Execute。運行,動態(tài)運行進(jìn)行輸出。

           

          所以說,在PHP內(nèi)部,本身也是存在編譯的過程。并且據(jù)此產(chǎn)生了大量的opcode cache工具,比如說apc、eacc、xcache等等。這些opcode cache在生產(chǎn)環(huán)境基本上在標(biāo)配?;趏pcode cache,能到做到“PHP腳本編譯一次,多次運行”的效果。從這點上,PHP就和JAVA的半編譯機(jī)制非常類似。

           

          所以,從運行機(jī)制上來看,PHP的運行模式和JAVA是非常類似的,都是先產(chǎn)生中間碼,然后運行在不同虛擬機(jī)上。

           

          2.5動態(tài)運行

           

          從上面的幾個分析來看,PHP在內(nèi)存管理、變量、函數(shù)、運行機(jī)制等幾個方面都做了大量的工作,所以從原理來看,PHP不應(yīng)該存在性能問題,性能至少也應(yīng)該和Java比較接近。

           

          這個時候就不得不談PHP動態(tài)語言的特性所帶來的性能問題了,由于PHP是動態(tài)運行時,所以所有的變量、函數(shù)、對象調(diào)用、作用域?qū)崿F(xiàn)等等都是在執(zhí)行 階段中才確定的。這個從根本上決定了PHP性能中很難改變的一些東西:在C/C++等能夠在靜態(tài)編譯階段確定的變量、函數(shù),在PHP中需要在動態(tài)運行中確 定,也就決定了PHP中間碼不能直接運行而需要運行在Zend Engine上。

           

          說到PHP變量的具體實現(xiàn),又不得不說一個東西了:Hashtable。Hashtable可以說在PHP靈魂之一,在PHP內(nèi)部廣泛用到,包含變量符號棧、函數(shù)符號棧等等都是基于hashtable的。

           

          以PHP變量為例來說明下PHP的動態(tài)運行特點,比如說代碼:

           

          $var = “hello, ”;

           

          ?>                          

          該代碼的執(zhí)行結(jié)果就是在變量符號棧(是一個hashtable)中新增一個項當(dāng)要使用到該變量時候,就去變量符合棧中去查找(也就是變量調(diào)用對出了一個hash查找的過程)。

           

          同樣對于函數(shù)調(diào)用也基本上類似有一個函數(shù)符號棧(hashtable)。

           

          其實關(guān)于動態(tài)運行的變量查找特點,在PHP的運行機(jī)制中也能看出一些。PHP代碼通過解釋、編譯后的流程下圖:

           

          從上圖可以看出,PHP代碼在compile之后,產(chǎn)出的了類符號表、函數(shù)符號表、和OPCODE。在真正執(zhí)行的時候,zend Engine會根據(jù)op code去對應(yīng)的符號表中進(jìn)行查找,處理。

           

          從某種程度上,在這種問題的上,很難找到解決方案。因為這是由于PHP語言的動態(tài)特性所決定的。但是在國內(nèi)外也有不少的人在尋找解決方案。因為通過這 樣,能夠從根本上完全的優(yōu)化PHP。典型的列子有facebook的hiphop()。

           

          2.6結(jié)論

           

          從上面分析來看,在基礎(chǔ)的內(nèi)存管理、變量、函數(shù)、運行機(jī)制方面,PHP本身并不會存在明顯的性能差異,但由于PHP的動態(tài)運行特性,決定了PHP和 其他的編譯型語言相比,所有的變量查找、函數(shù)運行等等都會多一些hash查找的CPU開銷和額外的內(nèi)存開銷,至于這種開銷具體有多大,可以通過后續(xù)的基準(zhǔn) 性能和對比分析得出。

           

          因此,也可以大體看出PHP不太適合的一些場景:大量計算性任務(wù)、大數(shù)據(jù)量的運算、內(nèi)存要求很嚴(yán)格的應(yīng)用場景。如果要實現(xiàn)這些功能,也建議通過擴(kuò)展的方式實現(xiàn),然后再提供鉤子函數(shù)給PHP調(diào)用。這樣可以減低內(nèi)部計算的變量、函數(shù)等系列開銷。

           

          3.基準(zhǔn)性能

           

          對于PHP基準(zhǔn)性能,目前缺少標(biāo)準(zhǔn)的數(shù)據(jù)。大多數(shù)同學(xué)都存在感性的認(rèn)識,有人認(rèn)為800QPS就是PHP的極限了。此外,對于框架的性能和框架對性能的影響很沒有響應(yīng)的權(quán)威數(shù)字。

           

          本章節(jié)的目的是給出一個基準(zhǔn)的參考性能指標(biāo),通過數(shù)據(jù)給大家一個直觀的了解。

           

          具體的基準(zhǔn)性能有以下幾個方面:

           

          1.裸PHP性能。完成基本的功能。

           

          2.裸框架的性能。只做最簡單的路由分發(fā),只走通核心功能。

           

          3.標(biāo)準(zhǔn)模塊的基準(zhǔn)性能。所謂標(biāo)準(zhǔn)模塊的基準(zhǔn)性能,是指一個具有完整服務(wù)模塊功能的基準(zhǔn)性能。

           

          3.1環(huán)境說明

           

          測試環(huán)境:

           

          Uname -a

           

          Linux db-forum-test17.db01. #1 SMP Wed Aug 12 17:35:51 CST 2009 x86_64 x86_64 x86_64 GNU/Linux

           

          Red Hat Enterprise Linux AS release 4 (Nahant Update 3)

           

          8 Intel(R) Xeon(R) CPU E5520 @ 2.27GHz

           

          軟件相關(guān):

           

          Nginx:

           

          nginx version: nginx/0.8.54 built by gcc 3.4.5 20051201 (Red Hat 3.4.5-2)

           

          PHP5:(采用PHP-fpm)

           

          PHP 5.2.8 (cli) (built: Mar 6 2011 17:16:18)

           

          Copyright (c) 1997-2008 The PHP Group

           

          Zend Engine v2.2.0, Copyright (c) 1998-2008 Zend Technologies

           

          with eAccelerator v0.9.5.3, Copyright (c) 2004-2006 eAccelerator, by eAccelerator

           

          bingo2:

           

          PHP框架。

           

          其他說明:

           

          目標(biāo)機(jī)器的部署方式:

           

          測試壓力機(jī)器和目標(biāo)機(jī)器獨立部署。

           

          3.2裸PHP性能

           

          最簡單的PHP腳本。

           

          require_once ‘./actions/indexAction.php’;

           

          $objAction = new indexAction();

           

          $objAction->init();

           

          $objAction->execute();

           

          ?>

           

          Acitons/indexAction.php里面的代碼如下

           

          class indexAction

           

          {

           

          public function execute()

           

          {

           

          echo ‘hello, world!’;

           

          }

           

          }

           

          ?>

           

          通過壓力工具測試結(jié)果如下:

          3.3裸PHP框架性能

           

          為了和3.2的對比,基于bingo2框架實現(xiàn)了類似的功能。代碼如下

           

          require_once ‘Bingo/Controller/Front.php’;

           

          $objFrontController = Bingo_Controller_Front::getInstance(array(

           

          ‘a(chǎn)ctionDir’ => ‘./actions’,

           

          ));

           

          $objFrontController->dispatch();

           

          壓力測試結(jié)果如下:

          從該測試結(jié)果可以看出:框架雖然有一定的消耗,但對整體的性能來說影響是非常小的。

           

          3.4標(biāo)準(zhǔn)PHP模塊的基準(zhǔn)性能

           

          所謂標(biāo)準(zhǔn)PHP模塊,是指一個PHP模塊所必須要具體的基本功能:

           

          路由分發(fā)。

           

          自動加載。

           

          LOG初始化&Notice日志打印。所以的UI請求都一條標(biāo)準(zhǔn)的日志。

           

          錯誤處理。

           

          時間校正。

           

          自動計算每個階段耗時開銷。

           

          編碼識別&編碼轉(zhuǎn)化。

           

          標(biāo)準(zhǔn)配置文件的解析和調(diào)用

           

          采用bingo2的代碼自動生成工具產(chǎn)生標(biāo)準(zhǔn)的測試PHP模塊:test。

           

          測試結(jié)果如下:

           

          3.5結(jié)論

           

          從測試數(shù)據(jù)的結(jié)論來看,PHP本身的性能還是可以的?;鶞?zhǔn)性能完全能夠達(dá)到幾千甚至上W的QPS。至于為什么在大多數(shù)的PHP模塊中表現(xiàn)不佳,其實 這個時候更應(yīng)該去找出系統(tǒng)的瓶頸點,而是簡單的說OK,PHP不行,那我們換C來搞吧。(下一個章節(jié),會通過一些例子來對比,采用C來處理不見得有特別的 優(yōu)勢)

           

          通過基準(zhǔn)數(shù)據(jù),可以得出以下幾個具體的結(jié)論:

           

          1.PHP本身性能也很不錯。簡單功能下能夠達(dá)到5000QPS,極限也能過W。

           

          2.PHP框架本身對性能影響非常有限。尤其是在有一定業(yè)務(wù)邏輯和數(shù)據(jù)交互的情況下,幾乎可以忽略。

           

          3.一個標(biāo)準(zhǔn)的PHP模塊,基準(zhǔn)性能能夠達(dá)到2000QPS(80 cpu idle)。

           

          4.對比分析

           

          很多時候,大家發(fā)現(xiàn)PHP模塊性能不行的時候,就來一句“ok,我們采用C重寫吧”。在公司內(nèi),采用C/C++來寫業(yè)務(wù)邏輯模塊的現(xiàn)象到處都有,在前幾年甚至幾乎全部都是采用C來寫。那時候大家寫的真是一個痛苦:調(diào)試難、敏捷不要談。



          php主動加載PHP提高編程效率的方法
          php基礎(chǔ)知識點總結(jié)PHP從零入門教程
          PHP內(nèi)核解密學(xué)習(xí)PHP的方法與技巧
          PHP7性能翻倍關(guān)鍵大揭秘如何遏制PHP木馬攻擊
          PHP編程教程Ajax完成分頁技巧MySQL讀寫分離由PHP實現(xiàn)
          談PHP生成靜態(tài)頁面PHP訪問MySQL
          PHP常用代碼 基于php的萬年歷接口調(diào)用代碼實例
          PHP培訓(xùn)之高級工程師應(yīng)具備哪些條件 PHP底層的運行機(jī)制-PHP從啟動到停止的整個生命周期
          信息發(fā)布:廣州名易軟件有限公司 http://www.jetlc.com
          • 勁爆價:
            不限功能
            不限用戶
            1998元/年

          • 微信客服

            <output id="r87xx"></output>
          1. 
            
            <mark id="r87xx"><thead id="r87xx"><input id="r87xx"></input></thead></mark>
              • 亚洲日韩欧美一区 | 亚洲成人网在线观看 | 日韩一二三区 | 乱伦天堂| 欧美成人精品欧美一级乱黄 | 国产久久久精品1000部视频 | 青青草乱伦免费视频 | 人操操操操操人人人 | 逼视频在线观看 | 三级国产网站 |