精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

大話PHP之性能

開發(fā) 前端 后端
本文就是圍繞這么一個(gè)話題來(lái)進(jìn)行探討的。從源碼、應(yīng)用場(chǎng)景、基準(zhǔn)性能、對(duì)比分析等幾個(gè)方面深入分析PHP之性能問(wèn)題,通過(guò)真實(shí)的性能數(shù)據(jù)來(lái)說(shuō)話,最終找出影響PHP模塊性能的關(guān)鍵因素。

關(guān)于PHP,很多人的直觀感覺(jué)是PHP是一種靈活的腳本語(yǔ)言,庫(kù)類豐富,使用簡(jiǎn)單,安全,非常適合WEB開發(fā),但性能低下。PHP的性能是否真的就如同大家的感覺(jué)一樣的差呢?本文就是圍繞這么一個(gè)話題來(lái)進(jìn)行探討的。從源碼、應(yīng)用場(chǎng)景、基準(zhǔn)性能、對(duì)比分析等幾個(gè)方面深入分析PHP之性能問(wèn)題,通過(guò)真實(shí)的性能數(shù)據(jù)來(lái)說(shuō)話,最終找出影響PHP模塊性能的關(guān)鍵因素。

從原理分析PHP性能

從原理分析PHP的性能,主要從以下幾個(gè)方面:內(nèi)存管理、變量、函數(shù)、運(yùn)行機(jī)制、網(wǎng)絡(luò)模型來(lái)進(jìn)行分析。

2.1內(nèi)存管理

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

2.2變量

總所周知,PHP是一種弱變量類型的語(yǔ)言,所以在PHP內(nèi)部,所有的PHP變量都對(duì)應(yīng)成一種類型Zval,其中具體定義如下:

 

 

圖一、PHP變量

在變量方面,PHP做了大量的優(yōu)化工作,比如說(shuō)Reference counting和copy on writer機(jī)制。這樣能夠保證內(nèi)存使用上的優(yōu)化,并且減少內(nèi)存拷貝次數(shù)(請(qǐng)參考http://blog.xiuwz.com/2011/11/09/php-using-internal-zval/)。在數(shù)組方面,PHP內(nèi)部采用高效的hashtable來(lái)實(shí)現(xiàn)。

2.3函數(shù)

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

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

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

  1. void zif_my_function ( INTERNAL_FUNCTION_PARAMETERS );  
  2. void zif_my_function(  
  3. int ht,  
  4. zval * return_value,  
  5. zval * this_ptr,  
  6. int return_value_used,  
  7. zend_executor_globals * executor_globals  
  8. ); 

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

2.4運(yùn)行機(jī)制

在話說(shuō)PHP性能的時(shí)候,很多人都會(huì)說(shuō)“C/C++是編譯型,JAVA是半編譯型,PHP是解釋型”。也就是說(shuō)PHP是先動(dòng)態(tài)解析再代碼運(yùn)行的,所以從這個(gè)角度來(lái)看,PHP性能必然很差。

的確,從PHP腳本運(yùn)行來(lái)輸出,的確是一個(gè)動(dòng)態(tài)解析再代碼運(yùn)行的過(guò)程。具體來(lái)說(shuō),PHP腳本的運(yùn)行機(jī)制如下圖所示:

 

 

圖二、PHP運(yùn)行機(jī)制

PHP的運(yùn)行階段也分成三個(gè)階段:

●Parse。語(yǔ)法分析階段。

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

● Execute。運(yùn)行,動(dòng)態(tài)運(yùn)行進(jìn)行輸出。

通過(guò)上圖也可以看出,其實(shí)在PHP內(nèi)部本身也是存在編譯的過(guò)程。事實(shí)上,在標(biāo)準(zhǔn)的生產(chǎn)環(huán)境中,也都基本上利用了這個(gè)特點(diǎn),比如說(shuō)opcode cache工具apc、eacc、xcache等等。基于opcode cache,能到做到“PHP腳本編譯一次,多次運(yùn)行”的效果。從這點(diǎn)上,PHP就和JAVA的半編譯機(jī)制非常類似。

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

2.5動(dòng)態(tài)運(yùn)行

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

但為什么還有很多人感覺(jué)PHP慢呢?尤其是一些計(jì)算量的性能對(duì)比上,總發(fā)現(xiàn)PHP處理的性能相對(duì)比較低效(http://shootout.alioth.debian.org/u32/php.php)。這個(gè)時(shí)候就不得不談PHP動(dòng)態(tài)語(yǔ)言的特性所帶來(lái)的性能問(wèn)題了,由于PHP是動(dòng)態(tài)運(yùn)行時(shí),所以所有的變量、函數(shù)、對(duì)象調(diào)用、作用域?qū)崿F(xiàn)等等都是在執(zhí)行階段中才確定的。這個(gè)從根本上決定了PHP性能中很難改變的一些東西:在C/C++等能夠在靜態(tài)編譯階段確定的變量、函數(shù),在PHP中需要在動(dòng)態(tài)運(yùn)行中確定,也就決定了PHP中間碼不能直接運(yùn)行而需要運(yùn)行在Zend Engine上。

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

以PHP變量為例來(lái)說(shuō)明下PHP的動(dòng)態(tài)運(yùn)行特點(diǎn),比如說(shuō)代碼:

  1. <?php 
  2. $var = “hello, blog.xiuwz.com”;  
  3. ?> 

該代碼的執(zhí)行結(jié)果就是在變量符號(hào)棧(是一個(gè)hashtable)中新增一個(gè)項(xiàng)

 

 

當(dāng)要使用到該變量時(shí)候,就去變量符合棧中去查找(也就是變量調(diào)用對(duì)出了一個(gè)hash查找的過(guò)程)。

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

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

 

 

圖3、PHP運(yùn)行實(shí)例

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

從某種程度上,在這種問(wèn)題的上,很難找到解決方案。因?yàn)檫@是由于PHP語(yǔ)言的動(dòng)態(tài)特性所決定的。但是在國(guó)內(nèi)外也有不少的人在尋找解決方案。因?yàn)橥ㄟ^(guò)這樣,能夠從根本上完全的優(yōu)化PHP。典型的列子有facebook的hiphop(https://github.com/facebook/hiphop-php)。

但所有的這種編譯優(yōu)化方案,都基本上是犧牲了PHP動(dòng)態(tài)運(yùn)行的特性。當(dāng)然可以在具體的編譯優(yōu)化中去對(duì)動(dòng)態(tài)特性做一些折中,但很難做到完完全全的兼容。

2.6網(wǎng)絡(luò)模型

目前采用PHP的方式,比較理想和通用的模式是采用fastcgi(PHP-FPM)。Php-fpm在網(wǎng)絡(luò)模型上比較類似nginx,采用了多進(jìn)程Master+多worker的模式。Php-fpm本身是基于libevent中的epoll模型。從網(wǎng)絡(luò)模型來(lái)看,該方式也不會(huì)和其他網(wǎng)絡(luò)模型存在性能差異。

2.7結(jié)論

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

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

3基準(zhǔn)性能

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

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

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

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

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

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

3.1環(huán)境說(shuō)明

測(cè)試環(huán)境:

Uname -a

Linux db-forum-test17.db01.baidu.com 2.6.9_5-7-0-0 #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框架。

其他說(shuō)明:

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

 

 

腳本。

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

3.2裸PHP性能

最簡(jiǎn)單的PHP腳本。

  1. <?php 
  2. require_once ‘./actions/indexAction.php’;  
  3. $objAction = new indexAction();  
  4. $objAction->init();  
  5. $objAction->execute();  
  6. ?> 

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

  1. <?php 
  2. class indexAction  
  3. {  
  4. public function execute()  
  5. {  
  6. echo ‘hello, world!’;  
  7. }  
  8. }  
  9. ?> 

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

 

 

3.3裸PHP框架性能

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

  1. <?php 
  2. require_once ‘Bingo/Controller/Front.php’;  
  3. $objFrontController = Bingo_Controller_Front::getInstance(array(  
  4. ‘actionDir’ => ‘./actions’,  
  5. ));  
  6. $objFrontController->dispatch();  
  7. ?> 

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

 

 

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

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

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

●路由分發(fā)。

●自動(dòng)加載。

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

●錯(cuò)誤處理。

●時(shí)間校正。

●自動(dòng)計(jì)算每個(gè)階段耗時(shí)開銷。

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

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

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

測(cè)試結(jié)果如下:

 

 

3.5結(jié)論

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

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

1、 PHP本身性能也很不錯(cuò)。簡(jiǎn)單功能下能夠達(dá)到5000QPS(50CPU IDLE),極限也能過(guò)W。

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

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

#p#

4 PHP與C性能對(duì)比分析

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

那么,本章節(jié)要談?wù)摰囊粋€(gè)話題就是:C寫的業(yè)務(wù)邏輯和PHP寫的業(yè)務(wù)邏輯模塊進(jìn)行性能對(duì)比,采用真實(shí)的數(shù)據(jù)來(lái)說(shuō)話。

4.1前提

為什么要特別說(shuō)出這個(gè)前提呢?因?yàn)樵诶硐肭闆r下,一個(gè)功能采用PHP實(shí)現(xiàn),該性能鐵定不可能比理想的C寫出來(lái)好。這個(gè)前提需要特別注意。

但為什么還要對(duì)比呢?因?yàn)樵诂F(xiàn)實(shí)情況下,能寫出非常優(yōu)秀的C程序,并且在頻繁修改的情況下還能做到完全高性能的又有幾個(gè)呢?并且在現(xiàn)實(shí)的應(yīng)用中C實(shí)現(xiàn)的性能是否真的全都都比PHP要好好幾倍呢?這些目前都沒(méi)有確切的數(shù)據(jù)來(lái)論證。

所以,本章節(jié)的對(duì)比是基于現(xiàn)實(shí)中的情況來(lái)進(jìn)行的,并采用真實(shí)數(shù)據(jù)來(lái)說(shuō)話。

4.2 真實(shí)業(yè)務(wù)模塊PHP模塊 VS C模塊

4.2.1業(yè)務(wù)模塊介紹

一個(gè)真實(shí)的案列,該業(yè)務(wù)模塊的流量高達(dá)數(shù)十億。該模塊的架構(gòu)圖如下:

 

 

圖4、業(yè)務(wù)模塊架構(gòu)圖

該業(yè)務(wù)模塊功能非常簡(jiǎn)單,上層是web server,下游是各個(gè)數(shù)據(jù)模塊。都是基于socket進(jìn)行數(shù)據(jù)交互。該業(yè)務(wù)模塊的主要工作模型是:響應(yīng)web server的請(qǐng)求,根據(jù)請(qǐng)求從各個(gè)后端數(shù)據(jù)模塊讀取相應(yīng)數(shù)據(jù),并根據(jù)數(shù)據(jù)產(chǎn)出最終的HTML頁(yè)面返回給web服務(wù)器。

為了方便后續(xù)介紹,定義CUI表示用C實(shí)現(xiàn)的模塊,PHPUI表示用PHP實(shí)現(xiàn)的模塊。

4.2.2C/C++模塊的性能數(shù)據(jù)結(jié)果

09年,該模塊重構(gòu)選擇了一個(gè)新的C/C++框架。當(dāng)時(shí)重構(gòu)的時(shí)候,該模塊連接的后端數(shù)據(jù)模塊規(guī)模在5-7個(gè)。

基于C/C++的模塊,最終測(cè)試數(shù)據(jù)數(shù)據(jù)分成兩個(gè)部分:

一、性能對(duì)比測(cè)試。

基于當(dāng)時(shí)線上壓力,進(jìn)行真實(shí)數(shù)據(jù)的性能測(cè)試。所以當(dāng)時(shí)只測(cè)試一個(gè)壓力數(shù)據(jù)如下:

壓力:210QPS

CPU(IDLE):84.18

二、極限性能測(cè)試1。

該測(cè)試模型是:CUI只連接一個(gè)核心數(shù)據(jù)模塊,其他數(shù)據(jù)模塊完全關(guān)閉。

 

 

三、極限性能測(cè)試2。

該測(cè)試模型是:CUI連接后端一個(gè)核心數(shù)據(jù)模塊,3個(gè)數(shù)據(jù)模塊,其他數(shù)據(jù)模塊不連接。

測(cè)試后性能數(shù)據(jù)如下:

 

 

4.2.3 PHP實(shí)現(xiàn)模塊的性能測(cè)試數(shù)據(jù)

到11年,基于09年的CUI基本上達(dá)到了代碼不看維護(hù)的地步。而且這個(gè)時(shí)候,CUI的極限性能已經(jīng)不到600QPS(主要原因是隨著項(xiàng)目的發(fā)展,后端數(shù)據(jù)模塊的數(shù)目增加到14個(gè))。據(jù)此,決定采用PHP方案來(lái)重寫整個(gè)模塊,并產(chǎn)出最終的pbui模塊。

性能測(cè)試結(jié)果分成兩種:

1、PHPUI連接一個(gè)核心模塊。測(cè)試數(shù)據(jù)如下:

 

 

圖5、PHPUI性能測(cè)試結(jié)果1

2、PHPUI連接后端所有模塊(14個(gè))。測(cè)試性能數(shù)據(jù)如下:

 

 

圖6、PHPUI性能測(cè)試結(jié)果2

4.2.4數(shù)據(jù)對(duì)比結(jié)論

由于PHPUI和CUI的業(yè)務(wù)邏輯和測(cè)試方法都不完全相同,所以抽取了部分大體能對(duì)比的點(diǎn)進(jìn)行整理。具體對(duì)比數(shù)據(jù)如下:

 

 

從上面的對(duì)比數(shù)據(jù)來(lái)看,在真實(shí)的業(yè)務(wù)項(xiàng)目中,PHPUI的性能并不會(huì)比CUI差。這個(gè)不是簡(jiǎn)簡(jiǎn)單單一個(gè)模塊來(lái)驗(yàn)證的,在部門里面,我們有不少模塊都是從C/C++遷移到PHP,從遷移的結(jié)果來(lái)看,并沒(méi)有存在質(zhì)的性能下降,大部分模塊遷移后性能指標(biāo)都是非常接近的。

這個(gè)時(shí)候就需要思考為什么會(huì)這樣了?細(xì)分來(lái)說(shuō)有兩個(gè)問(wèn)題:

1、 為什么在真實(shí)業(yè)務(wù)項(xiàng)目中,PHPUI的性能并不會(huì)比CUI差太多?

2、 為什么基準(zhǔn)的PHP性能這么高,80CPU的情況下2000QPS,但到了真實(shí)的PHP模塊中只能是200QPS?

其實(shí)這兩個(gè)問(wèn)題,也可以歸結(jié)成一種原因:在真實(shí)業(yè)務(wù)項(xiàng)目中,影響性能更多的不是說(shuō)采用了什么語(yǔ)言,而是其業(yè)務(wù)相關(guān)的部分,比如說(shuō)socket交互次數(shù),比如說(shuō)字符串處理,也比如說(shuō)網(wǎng)絡(luò)交互包大小。

OK。那么接下來(lái)的關(guān)鍵是找出影響性能的關(guān)鍵因素。

4.2.5影響PHP模塊性能的關(guān)鍵因素

從前面分析,我們得出,影響前端PHP模塊性能的關(guān)鍵因素不是語(yǔ)言本身(是否是PHP/JAVA/C都不重要)。那么到底影響PHP業(yè)務(wù)模塊性能的關(guān)鍵因素在哪里呢?CPU耗時(shí)是統(tǒng)計(jì)一個(gè)項(xiàng)目性能的關(guān)鍵點(diǎn)之一,考慮到系統(tǒng)中都打印出了系列日志。通過(guò)分析日志中請(qǐng)求的耗時(shí)分布可以大體上看出關(guān)鍵點(diǎn)。

在我們系統(tǒng)中,CPU耗時(shí)重點(diǎn)打印出以下幾個(gè)方面:

1、 請(qǐng)求總時(shí)間。

2、 請(qǐng)求關(guān)鍵函數(shù)的性能,其中所有的socket交互都有耗時(shí)計(jì)算。

3、 模版渲染也是好事的一個(gè)關(guān)鍵點(diǎn)。

在前面分析中,我們基本上判定socket和字符串處理是一個(gè)關(guān)鍵點(diǎn)之一,通過(guò)數(shù)據(jù)我們來(lái)驗(yàn)證下。抽取一個(gè)模塊指定數(shù)目的日志,進(jìn)行綜合分析得出以下數(shù)據(jù):

 

 

通過(guò)這個(gè)可以看出,在一個(gè)業(yè)務(wù)模塊中,影響***的是socket數(shù)據(jù)交互,其次是大量的字符串處理。具體細(xì)分來(lái)說(shuō)是以下幾個(gè)因素:socket交互次數(shù)、socket交互包大小、socket交互響應(yīng)時(shí)間、字符串處理。

4.2.6結(jié)論

通過(guò)上述分析,可以得出以下結(jié)論:在前端業(yè)務(wù)模塊中,PHP語(yǔ)言本身不會(huì)成為性能瓶頸。因?yàn)橛绊懶阅艿膸讉€(gè)關(guān)鍵因數(shù)是:

● 網(wǎng)絡(luò)交互數(shù)目。

● 網(wǎng)絡(luò)交互數(shù)據(jù)大小,包含數(shù)據(jù)打包解包開銷。

● 網(wǎng)絡(luò)交互響應(yīng)時(shí)間。

● 大量的字符串處理。

5最終結(jié)論

通過(guò)上述三個(gè)章節(jié)的具體分析,可以得出以下結(jié)論:

1、從PHP實(shí)現(xiàn)原理來(lái)看,PHP屬于半編譯型語(yǔ)言,并且在各個(gè)方面都進(jìn)行了大量的優(yōu)化工作,本身不會(huì)存在明顯的性能問(wèn)題。但由于動(dòng)態(tài)語(yǔ)言的特性,決定了PHP需要運(yùn)行在Zend Engine虛擬機(jī)上,并且在變量查找、函數(shù)調(diào)用、作用域切換等各個(gè)方面需要一些額外開銷。

2、從PHP的基準(zhǔn)性能來(lái)看,PHP本身不會(huì)存在明顯的資源消耗,單機(jī)QPS能夠輕松過(guò)W, PHP框架本身也不會(huì)對(duì)業(yè)務(wù)系統(tǒng)的性能帶來(lái)關(guān)鍵性的影響。

3、從真實(shí)的應(yīng)用場(chǎng)景來(lái)看,基于C語(yǔ)言實(shí)現(xiàn)的模塊不見得比基于PHP實(shí)現(xiàn)的模塊性能高效很多。因?yàn)樵谡鎸?shí)的應(yīng)用場(chǎng)景中,更多的性能開銷在于網(wǎng)絡(luò)數(shù)據(jù)交互和字符串處理。語(yǔ)言方面微小的性能差異不會(huì)成為瓶頸。

據(jù)此,可以推出:基于C語(yǔ)言實(shí)現(xiàn)的大部分業(yè)務(wù)系統(tǒng)都可以考慮遷移到PHP上來(lái),一方面能夠快速開發(fā),另外一方面性能也不會(huì)存在問(wèn)題。

***,關(guān)于影響PHP性能的關(guān)鍵因素的具體分析和關(guān)于語(yǔ)言函數(shù)級(jí)別PHP與C的基準(zhǔn)性能對(duì)比分析,請(qǐng)關(guān)注下文《深入探討PHP性能問(wèn)題》。

原文:http://stblog.baidu-tech.com/?p=1343

【編輯推薦】

  1. 如果PHP是用英式英語(yǔ)編寫的
  2. 手把手教你在Ubuntu上安裝Apache、MySql和PHP
  3. 新浪微博API開發(fā)簡(jiǎn)介之用戶授權(quán)(PHP基礎(chǔ)篇)
  4. 技術(shù)達(dá)人談PHP底層工作原理
  5. Web開發(fā)者必備的10個(gè)救命的PHP代碼片段
責(zé)任編輯:陳貽新 來(lái)源: 百度搜索研發(fā)部官博
相關(guān)推薦

2011-07-09 23:24:57

PHP

2018-05-14 09:28:24

RAID磁盤存儲(chǔ)

2023-12-31 19:41:04

PHP性能終端

2011-03-11 15:53:00

LAMP優(yōu)化

2018-04-09 08:17:36

線程ThreadLocal數(shù)據(jù)

2011-07-04 14:57:56

PHP

2011-07-04 14:33:07

PHP

2011-02-14 09:18:06

QT-Quick

2011-02-25 09:00:00

MeeGo微軟諾基亞

2012-11-23 13:09:38

PHP性能

2009-12-09 17:33:22

PHP性能優(yōu)化

2018-09-14 11:00:33

操作系統(tǒng)存儲(chǔ)管理

2018-06-20 19:57:40

桌面虛擬

2018-05-22 09:11:27

塊存儲(chǔ)LUN文件系統(tǒng)

2018-06-11 10:47:20

IDV虛擬化虛擬桌面

2012-02-17 15:49:11

技術(shù)沙龍

2015-08-18 11:44:02

PHP性能分析宏觀分析

2015-09-14 10:41:51

PHP性能分析微觀分析

2011-08-05 10:01:47

MySQL庫(kù)Pdo-MysqlMysqli

2018-06-06 08:54:23

數(shù)據(jù)結(jié)構(gòu)存儲(chǔ)
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)

一级片黄色免费| 波多野结衣 作品| 亚洲一区精品在线观看| 久久久久电影| 亚洲国产精品视频在线观看| av免费观看大全| 婷婷在线视频观看| 丁香六月综合激情| 国产精品久久久久久av| 久久高清无码视频| 精品美女久久| 精品久久久久久最新网址| 日韩av在线综合| 在线视频观看国产| 国产欧美一区二区精品性| 99视频日韩| 最新中文字幕免费| 在线一区免费观看| 久久偷看各类女兵18女厕嘘嘘| 免费黄色三级网站| av在线亚洲一区| 色综合天天性综合| 麻豆映画在线观看| 69xxxx欧美| 久久亚区不卡日本| 国产精品免费在线播放| 国产又粗又猛又色又| 久久先锋影音| 久久久免费高清电视剧观看| 亚洲综合图片一区| 久久av网址| 亚洲第一黄色网| 精品人妻一区二区三| 福利视频一区| 一本色道**综合亚洲精品蜜桃冫| 久久av高潮av| caopo在线| 亚洲视频香蕉人妖| 亚洲精品无人区| 韩日视频在线| 久久久久久久网| 久久综合毛片| 全色精品综合影院| 不卡的av在线| 国产三级精品在线不卡| 噜噜噜久久,亚洲精品国产品| 国产制服丝袜一区| 国产欧美精品日韩精品| 最近中文字幕在线免费观看| 天堂久久久久va久久久久| 欧洲美女7788成人免费视频| 亚洲黄色小说图片| 亚洲欧美视频| 日本久久久久久久久| 欧美国产成人精品一区二区三区| 一区二区激情| 欧美一二三视频| 欧美福利视频一区二区| 亚洲深夜激情| 日本欧美在线视频| 亚洲天堂五月天| 奇米亚洲午夜久久精品| 国产精品中文久久久久久久| 亚洲无码久久久久| 国内成+人亚洲+欧美+综合在线| 国产一区二中文字幕在线看| 91亚洲视频在线观看| 国产尤物一区二区| 99久久99久久精品国产片| 日本美女一级视频| 久久免费的精品国产v∧| 热re99久久精品国产99热| 成人av电影观看| 一区免费观看视频| 国产精品视频一二三四区| 三级福利片在线观看| 亚洲成人午夜电影| 黄色av免费在线播放| 日韩三级一区| 亚洲第一中文字幕在线观看| 日韩一区二区a片免费观看| 成人午夜国产| 欧美激情在线狂野欧美精品| 日韩精品成人一区| 免播放器亚洲一区| 成人免费看片网站| 全部免费毛片在线播放网站| 国产精品国产三级国产有无不卡 | 精品少妇人妻av一区二区三区| 麻豆一区一区三区四区| 国产一区二区三区在线免费观看| 中日韩一级黄色片| 一区二区福利| 91丨九色丨国产在线| 污视频网站在线播放| 国产精品午夜在线| 日韩美女爱爱视频| 国产日本久久| 日韩成人激情在线| 搜索黄色一级片| 一区二区三区高清视频在线观看| 国产综合视频在线观看| 手机福利小视频在线播放| 国产精品青草久久| 91国视频在线| 日韩精品一区国产| 中文欧美日本在线资源| 国产成人无码精品久久久久| 国产一区二区三区免费| 欧洲视频一区二区三区| 国产丝袜在线播放| 4438x亚洲最大成人网| 国产麻豆天美果冻无码视频| 欧美1区免费| 国产日韩在线视频| 蜜桃视频在线观看网站| 18欧美乱大交hd1984| 国产偷人视频免费| 成人午夜大片| 欧美精品少妇videofree| 最新中文字幕在线观看视频| 99天天综合性| 国产美女永久无遮挡| 99re8精品视频在线观看| 亚洲三级av在线| 国产微拍精品一区| 成人激情午夜影院| 妺妺窝人体色www看人体| 日韩深夜福利网站| 日韩中文字幕在线播放| 波多野结衣影片| 91欧美激情一区二区三区成人| 成人午夜免费在线视频| 免费观看亚洲天堂| 久久精品国产精品亚洲| 中文字幕一区二区人妻| 国产日本欧洲亚洲| 日韩一级免费在线观看| 久久97视频| 国产成人精品免费久久久久| 牛牛澡牛牛爽一区二区| 欧美日韩亚洲91| 中文字幕一区二区久久人妻网站| 99亚洲精品| 国产一区二区视频在线免费观看 | 日韩欧美午夜| 国产精品自产拍高潮在线观看| 激情小视频在线| 日本久久一区二区三区| 91精品久久久久久久久久久久| 丝袜美腿亚洲一区二区图片| 免费中文日韩| 我爱我色成人网| 中文字幕精品视频| 国产精品一区二区人人爽| 亚洲天堂精品视频| 下面一进一出好爽视频| 好吊一区二区三区| 国产一区二区中文字幕免费看| 国产极品在线观看| 亚洲欧美在线一区二区| 在线观看国产区| 亚洲欧美在线另类| 久久黄色一级视频| a91a精品视频在线观看| 欧美日韩国产一二| 国产精品亲子伦av一区二区三区| 久久精品视频播放| 亚洲成人久久精品| 欧美日韩精品在线观看| 久久丫精品忘忧草西安产品| 美女视频黄 久久| 黑人巨大国产9丨视频| xvideos.蜜桃一区二区| 欧美中文字幕视频| 久久久久久久久免费视频| 欧美xxxx老人做受| 日本a级c片免费看三区| 国产精品国产三级国产普通话三级| 宇都宫紫苑在线播放| 99精品热视频只有精品10| 日韩免费一区二区三区| 欧美一区在线观看视频| 欧美影院久久久| 亚洲成人影院麻豆| 日韩一本二本av| 欧美激情黑白配| 成人欧美一区二区三区视频网页| 香蕉久久久久久av成人| 欧美在线综合| 国产资源第一页| 久久99国产精品视频| 99精品在线直播| 亚洲精品555| 国产做受高潮69| www.久久热.com| 亚洲第五色综合网| 国产精品天天操| 一本大道久久精品懂色aⅴ| 中国毛片直接看| 久久婷婷久久一区二区三区| 日本中文字幕精品| 日本在线不卡视频| 黄色片网址在线观看| 国产精品成人a在线观看| 美女视频久久| 亚洲精品黑牛一区二区三区| 国产精品一区二区电影| 黄毛片在线观看| 色综合久久精品亚洲国产| 国产黄色片在线观看| 亚洲精品短视频| 性生活视频软件| 欧美一级理论片| 亚洲视频一区在线播放| 欧美午夜宅男影院在线观看| 精品无码久久久久久久久| 国产精品不卡一区| 91在线无精精品白丝| 26uuu国产电影一区二区| 成人做爰www看视频软件| 国产一区二区福利视频| 色婷婷综合网站| 日韩精品五月天| 日韩免费视频播放| 激情文学一区| 成人国产在线看| 亚洲乱码电影| 伊人色综合影院| 99精品在线| 亚洲激情图片| 日本激情一区| 视频一区视频二区视频三区高| 亚洲传媒在线| 欧美激情一区二区三区在线视频 | 激情伊人五月天久久综合| 黑鬼大战白妞高潮喷白浆| 国产亚洲精品bv在线观看| 日韩网站在线免费观看| 在线日本高清免费不卡| 亚洲国产精品无码观看久久| 激情视频一区二区三区| 国产美女主播在线播放| 亚洲欧洲午夜| 91猫先生在线| 久久精品国语| 欧美性大战久久久久xxx| 欧美专区一区二区三区| 激情五月亚洲色图| 日本vs亚洲vs韩国一区三区二区| 国产又大又黄又粗的视频| 日本中文字幕一区二区视频| 天天插天天操天天射| 久久99精品久久久久久| 午夜国产福利在线观看| 国产精品一区二区你懂的| 久草福利在线观看| a级高清视频欧美日韩| av直播在线观看| 欧美激情一区二区三区不卡 | 色中色一区二区| 国产精品第六页| 欧美精品视频www在线观看| 国产乱人乱偷精品视频a人人澡| 日韩一区二区三区在线视频| 人妻精品一区二区三区| 亚洲欧美成人在线| 999在线视频| 欧美成年人网站| 嗯啊主人调教在线播放视频 | 欧美激情成人网| 另类专区欧美蜜桃臀第一页| 毛毛毛毛毛毛毛片123| 成人午夜av电影| 中文字幕 自拍| 亚洲精品视频一区二区| 久久久久久久极品| 欧美日韩在线三区| 亚洲精品免费在线观看视频| 亚洲人成网站999久久久综合| 日本免费在线观看| 国内精品美女av在线播放| 91精品xxx在线观看| 91欧美激情另类亚洲| 欧美性生活一级片| 亚洲区一区二区三区| 国产主播一区| www.色就是色| 丰满少妇久久久久久久| 久久久久久久毛片| 亚洲国产美女搞黄色| 波多野结衣在线电影| 亚洲成人aaa| av电影在线观看| 国内精品久久久久久久久| 国产第一精品| 久久99精品久久久久久久青青日本 | 日韩高清不卡av| 成年人黄视频在线观看| 日本国产欧美一区二区三区| 欧美第一在线视频| 天堂社区 天堂综合网 天堂资源最新版| 国产精品www994| 玖玖爱视频在线| 久久久不卡影院| 欧美精品久久久久性色| 欧美色图天堂网| 日韩一二三四| 久久免费精品日本久久中文字幕| 黄色成人小视频| 久久艹中文字幕| 亚洲天堂成人| 伊人成人免费视频| 国产精品麻豆久久久| 中文字幕第15页| 亚洲精品美女久久久| 七七久久电影网| 91在线观看欧美日韩| av中文一区| 苍井空浴缸大战猛男120分钟| 91原创在线视频| 免费一级黄色大片| 91精品国产高清一区二区三区| 高清av电影在线观看| 91成人福利在线| 国产一区丝袜| 人妻互换免费中文字幕| 国产美女一区二区| 欧美成人777| 在线电影国产精品| 欧美成人hd| 成人免费网站在线| 91影院成人| 91pony九色| 亚洲欧美色图小说| 国产99久一区二区三区a片| www.亚洲男人天堂| 亚洲精品三区| 欧美少妇一级片| 国产一区不卡在线| 国产精品第九页| 精品成人一区二区三区四区| jizz一区二区三区| 国产一区二区三区高清| 在线电影一区| 精品黑人一区二区三区观看时间| 亚洲v精品v日韩v欧美v专区| 少妇av一区二区| 欧美中文字幕第一页| 欧美精品一区二区三区精品| the porn av| 亚洲欧美在线aaa| 精品区在线观看| 欧美激情区在线播放| 粉嫩一区二区三区四区公司1| 成熟丰满熟妇高潮xxxxx视频| 久久久久9999亚洲精品| 午夜精品久久久久久久蜜桃| 中文字幕在线看视频国产欧美| 色综合一区二区日本韩国亚洲 | 日韩一卡二卡三卡四卡| 日本片在线看| 久久99九九| 青青草国产精品97视觉盛宴| 女人18毛片毛片毛片毛片区二| 日韩女优视频免费观看| 久久久男人天堂| 亚洲成人在线视频网站| 黑人精品欧美一区二区蜜桃| 久热精品在线观看| 亚洲欧美国产日韩中文字幕| 啪啪av大全导航福利综合导航| 欧美一级黄色录像片| av电影在线观看不卡| 日本视频www色| 九九热精品在线| 亚洲a级精品| 伊人色在线视频| 婷婷丁香激情综合| eeuss影院www在线观看| 成人在线观看网址| 日韩国产欧美视频| 玖玖爱免费视频| 一本色道久久88综合亚洲精品ⅰ | 久久亚洲综合网| 久久精品国产久精国产爱| 久久精品性爱视频| 尤物tv国产一区| 99国产精品免费网站| 成人三级视频在线播放| 亚洲精品乱码久久久久久久久| 日本亚洲一区| www.成人av.com| 人人狠狠综合久久亚洲| 久久久久亚洲av无码专区| 亚洲欧美一区二区三区久久| 日韩高清在线观看一区二区| 中文字幕欧美人妻精品一区| 亚洲永久精品大片| 91社区在线高清|