本文實(shí)例分析了PHP性能測(cè)試工具xhprof安裝與使用方法。分享給大家供大家參考,具體如下:
xhprof概述:
XHProf是一個(gè)分層PHP性能分析工具。它報(bào)告函數(shù)級(jí)別的請(qǐng)求次數(shù)和各種指標(biāo),包括阻塞時(shí)間,CPU時(shí)間和內(nèi)存使用情況。一個(gè)函數(shù)的開銷,可細(xì)分成調(diào)用者和被調(diào)用者的開銷,XHProf數(shù)據(jù)收集階段,它記錄調(diào)用次數(shù)的追蹤和包容性的指標(biāo)弧在動(dòng)態(tài)callgraph的一個(gè)程序。它獨(dú)有的數(shù)據(jù)計(jì)算的報(bào)告/后處理階段。在數(shù)據(jù)收集時(shí),XHProfd通過檢測(cè)循環(huán)來處理遞歸的函數(shù)調(diào)用,并通過給遞歸調(diào)用中每個(gè)深度的調(diào)用一個(gè)有用的命名來避開死循環(huán)。XHProf分析報(bào)告有助于理解被執(zhí)行的代碼的結(jié)構(gòu),它有一個(gè)簡單的HTML的用戶界面( PHP寫成的)。基于瀏覽器的性能分析用戶界面能更容易查看,或是與同行們分享成果。也能繪制調(diào)用關(guān)系圖。
安裝與使用:
最近要做網(wǎng)站的性能對(duì)比,于是就找一款性能測(cè)試工作來玩玩,工具很多,但相比之前還是覺得xhprof的安裝和使用相對(duì)來說簡單點(diǎn),數(shù)據(jù)分析也都還可以,下面就說說它的安裝和使用。。。
下載xhprof和graphviz
xhprof的話,直接去php官網(wǎng)就可以下載,為了方便可以戳一下 這里
graphviz的話也要下載,主要是顯示xhprof性能結(jié)果的圖形報(bào)表,戳這里 這里
編譯安裝xhprof
cd xhprof-0.9.4/xhprof-0.9.4/extension/phpize./configuremakesudo make install
將生成的xhprof.so文件加到php.ini文件中,然后重啟apache了
...#這里要使用相對(duì)路徑加載的話首先要看一下extension_dir配置的路徑,或者直接寫上`.so`文件的絕對(duì)能夠路徑即可。。。extension=xhprof.so...sudo apachectl restart##測(cè)試擴(kuò)展是否安裝成功,有如下輸出則okphp --ri xhprof... xhprof xhprof => 0.9.2 CPU num => 4...
安裝graphviz
cd graphviz-2.38.0/#后面參數(shù)是要確保安裝了libphp才行哦【沒安裝的 brew install linpng 就可】./configure --with-png=yesmakesudo make install
測(cè)試一下了
在之前下載的xhprof文件夾里面,找到xhprof_html,xhprof_lib、sample三個(gè)文件夾,那這三個(gè)文件夾放到你可以訪問到得地方去,然后通過連接先訪問以下http://xxxx/sample/sample.php,在訪問以下http://xxxx/xhprof_html/,就會(huì)看到有一條記錄,點(diǎn)擊后就可以看到分析結(jié)果頁面,通過點(diǎn)擊 View Full CallGraph鏈接到圖形報(bào)表的頁面。
如何使用
假設(shè)你現(xiàn)在要看看看自己做的一個(gè)網(wǎng)站的首頁性能數(shù)據(jù),那么你要找到這個(gè)網(wǎng)站的首頁入口文件,在核心文件加載之前和之后分別加上xhprof的性能測(cè)試代碼
#開啟,具體參數(shù)說明可以查看官方文檔xhprof_enable(XHPROF_FLAGS_NO_BUILTINS | XHPROF_FLAGS_CPU | XHPROF_FLAGS_MEMORY);#核心文件的執(zhí)行...require 'index.php'...#關(guān)閉$xhprof_data = xhprof_disable();#這里的路徑根據(jù)自己的站點(diǎn)來配置$XHPROF_ROOT = realpath(dirname(__FILE__) .'/');include_once $XHPROF_ROOT . "/xhprof_lib/utils/xhprof_lib.php";include_once $XHPROF_ROOT . "/xhprof_lib/utils/xhprof_runs.php";$xhprof_runs = new XHProfRuns_Default();$run_id = $xhprof_runs->save_run($xhprof_data, "xhprof");#這里打印出本次測(cè)試的id,方便到報(bào)表列表頁面【http://xxxx/xhprof_html/】去通過對(duì)應(yīng)的id找到對(duì)應(yīng)的結(jié)果var_dump($run_id);
希望本文所述對(duì)大家PHP程序設(shè)計(jì)有所幫助。
新聞熱點(diǎn)
疑難解答
圖片精選