PHP性能測(cè)試工具xhprof安裝與使用方法詳解
本文實(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寫成的)?;跒g覽器的性能分析用戶界面能更容易查看,或是與同行們分享成果。也能繪制調(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 ./configure make sudo make install
將生成的xhprof.so文件加到php.ini文件中,然后重啟apache了
... #這里要使用相對(duì)路徑加載的話首先要看一下extension_dir配置的路徑,或者直接寫上`.so`文件的絕對(duì)能夠路徑即可。。。 extension=xhprof.so ... sudo apachectl restart ##測(cè)試擴(kuò)展是否安裝成功,有如下輸出則ok php --ri xhprof ... xhprof xhprof => 0.9.2 CPU num => 4 ...
安裝graphviz
cd graphviz-2.38.0/ #后面參數(shù)是要確保安裝了libphp才行哦【沒安裝的 brew install linpng 就可】 ./configure --with-png=yes make sudo 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);
更多關(guān)于PHP相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《PHP擴(kuò)展開發(fā)教程》、《php緩存技術(shù)總結(jié)》、《PHP網(wǎng)絡(luò)編程技巧總結(jié)》、《php面向?qū)ο蟪绦蛟O(shè)計(jì)入門教程》、《PHP基本語法入門教程》、《PHP數(shù)組(Array)操作技巧大全》及《php字符串(string)用法總結(jié)》
希望本文所述對(duì)大家PHP程序設(shè)計(jì)有所幫助。
相關(guān)文章
php array_map使用自定義的函數(shù)處理數(shù)組中的每個(gè)值
這篇文章主要介紹了php array_map使用自定義的函數(shù)處理數(shù)組中的每個(gè)值的相關(guān)資料,需要的朋友可以參考下2016-10-10PHP與MongoDB簡介|安全|M+PHP應(yīng)用實(shí)例詳解
本篇文章是對(duì)PHP中的MongoDB簡介|安全|M+PHP應(yīng)用實(shí)例進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-06-06php5 圖片驗(yàn)證碼實(shí)現(xiàn)代碼
php5 圖片驗(yàn)證碼,需要的朋友可以參考下。2009-12-12php計(jì)算兩個(gè)整數(shù)的最大公約數(shù)常用算法小結(jié)
這篇文章主要介紹了php計(jì)算兩個(gè)整數(shù)的最大公約數(shù)常用算法,實(shí)例總結(jié)了求最大公約數(shù)的三種常用方法,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-03-03