php性能瓶頸分析:xhprof

xhprof簡(jiǎn)介

下載安裝與配置

1畅卓、下載

cd $ROOT_PATH/webroot 
wget -nv 'ftp://getprod:getprod@product.scm.baidu.com:/data/prod-64/inf/odp/tools/perftool/perftool_1-0-2_BL/output/perftool.tar.gz'
tar xzf perftool.tar.gz

2、安裝與配置

如果是PHP蟋恬,修改php/etc/ext/xhprof.ini翁潘,并重啟php-cgi:

[xhprof]
extension="xhprof.so"

如果是HHVM,修改hhvm/conf/hhvm.hdf歼争,開啟xhprof開關(guān)拜马,并重啟hhvm:

Stats {
    EnableHotProfiler = true
}

3、其他
想要在瀏覽器中查看結(jié)果文件矾飞,需要確認(rèn)下nginx中的配置是否包含所有index.php一膨,否則呀邢,需要自己配置洒沦,如下所示:

#nginx.conf
     location ~ ^/perftool/.*\.php$ {
     root    $ROOT_DIR/webroot;
     fastcgi_pass    $php_upstream;
     fastcgi_index   index.php;
     include         fastcgi.conf;
  }
  
  location ~ ^/perftool/ {
     root   $ROOT_DIR/webroot;
     index     index.php;
  }

使用

1、記錄全局使用 价淌,在index.php中申眼,其他在出口入口

require_once('/xxx/webroot/perftool/xhprof/include.php');
#出口處
XHProf::enable();
#結(jié)束的地方
XHProf::disable();

2、結(jié)果分析查看:
查看剛剛的接口性能鏈接:

http://xxx:8080/perftool/xhprof/xhprof_html/index.php?

結(jié)果如下圖所示:默認(rèn)是按Inc Wall Time(每個(gè)函數(shù)執(zhí)行總時(shí)間蝉衣,包含其調(diào)用的子函數(shù)的執(zhí)行時(shí)間)排列的括尸,各個(gè)解釋如后續(xù)引用:

image.png

Calls:函數(shù)的調(diào)用次數(shù)
Incl. Wall Time (microsec) :包含內(nèi)部函數(shù)花費(fèi)的時(shí)間,單位微秒
Excl. Wall Time (microsec):不包含內(nèi)部函數(shù)花費(fèi)的時(shí)間病毡,單位微秒
及所占百分比(%)

注:Incl.:為 Including 包含的簡(jiǎn)寫
Excl.:為 Excluding 不包含的簡(jiǎn)寫
Wall Time:意為掛鐘時(shí)間即任務(wù)花費(fèi)的時(shí)間

想知道哪個(gè)函數(shù)最花時(shí)間濒翻,應(yīng)該看Excl Wall Time(每個(gè)函數(shù)執(zhí)行時(shí)間,不包含其調(diào)用子函數(shù)的時(shí)間)啦膜,點(diǎn)擊按Excl Wall Time排列


image.png

發(fā)現(xiàn)花費(fèi)時(shí)間較多的是:
mysqli::query 和mysqli::real_connect 以及file_put_contents有送,file的可以通過后續(xù)文件上傳專門服務(wù)器解決,但是數(shù)據(jù)庫(kù)性能的問題如何解決僧家,需要再調(diào)研雀摘。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市八拱,隨后出現(xiàn)的幾起案子阵赠,更是在濱河造成了極大的恐慌涯塔,老刑警劉巖,帶你破解...
    沈念sama閱讀 216,919評(píng)論 6 502
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件清蚀,死亡現(xiàn)場(chǎng)離奇詭異匕荸,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)枷邪,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,567評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門每聪,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人齿风,你說我怎么就攤上這事药薯。” “怎么了救斑?”我有些...
    開封第一講書人閱讀 163,316評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵童本,是天一觀的道長(zhǎng)。 經(jīng)常有香客問我脸候,道長(zhǎng)穷娱,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,294評(píng)論 1 292
  • 正文 為了忘掉前任运沦,我火速辦了婚禮泵额,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘携添。我一直安慰自己嫁盲,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,318評(píng)論 6 390
  • 文/花漫 我一把揭開白布烈掠。 她就那樣靜靜地躺著羞秤,像睡著了一般。 火紅的嫁衣襯著肌膚如雪左敌。 梳的紋絲不亂的頭發(fā)上瘾蛋,一...
    開封第一講書人閱讀 51,245評(píng)論 1 299
  • 那天,我揣著相機(jī)與錄音矫限,去河邊找鬼哺哼。 笑死,一個(gè)胖子當(dāng)著我的面吹牛叼风,可吹牛的內(nèi)容都是我干的取董。 我是一名探鬼主播,決...
    沈念sama閱讀 40,120評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼咬扇,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼甲葬!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起懈贺,我...
    開封第一講書人閱讀 38,964評(píng)論 0 275
  • 序言:老撾萬榮一對(duì)情侶失蹤经窖,失蹤者是張志新(化名)和其女友劉穎坡垫,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體画侣,經(jīng)...
    沈念sama閱讀 45,376評(píng)論 1 313
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡冰悠,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,592評(píng)論 2 333
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了配乱。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片溉卓。...
    茶點(diǎn)故事閱讀 39,764評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖搬泥,靈堂內(nèi)的尸體忽然破棺而出桑寨,到底是詐尸還是另有隱情,我是刑警寧澤忿檩,帶...
    沈念sama閱讀 35,460評(píng)論 5 344
  • 正文 年R本政府宣布尉尾,位于F島的核電站,受9級(jí)特大地震影響燥透,放射性物質(zhì)發(fā)生泄漏沙咏。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,070評(píng)論 3 327
  • 文/蒙蒙 一班套、第九天 我趴在偏房一處隱蔽的房頂上張望肢藐。 院中可真熱鬧,春花似錦吱韭、人聲如沸吆豹。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,697評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)瞻讽。三九已至鸳吸,卻和暖如春熏挎,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背晌砾。 一陣腳步聲響...
    開封第一講書人閱讀 32,846評(píng)論 1 269
  • 我被黑心中介騙來泰國(guó)打工坎拐, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人养匈。 一個(gè)月前我還...
    沈念sama閱讀 47,819評(píng)論 2 370
  • 正文 我出身青樓哼勇,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親呕乎。 傳聞我的和親對(duì)象是個(gè)殘疾皇子积担,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,665評(píng)論 2 354

推薦閱讀更多精彩內(nèi)容

  • php.ini設(shè)置,上傳大文件: post_max_size = 128Mupload_max_filesize ...
    bycall閱讀 6,756評(píng)論 3 64
  • PHP常用函數(shù)大全 usleep() 函數(shù)延遲代碼執(zhí)行若干微秒。 unpack() 函數(shù)從二進(jìn)制字符串對(duì)數(shù)據(jù)進(jìn)行解...
    上街買菜丶迷倒老太閱讀 1,369評(píng)論 0 20
  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理猬仁,服務(wù)發(fā)現(xiàn)帝璧,斷路器先誉,智...
    卡卡羅2017閱讀 134,654評(píng)論 18 139
  • php usleep() 函數(shù)延遲代碼執(zhí)行若干微秒。 unpack() 函數(shù)從二進(jìn)制字符串對(duì)數(shù)據(jù)進(jìn)行解包的烁。 uni...
    思?jí)鬚HP閱讀 1,984評(píng)論 1 24
  • Php:腳本語(yǔ)言褐耳,網(wǎng)站建設(shè),服務(wù)器端運(yùn)行 PHP定義:一種服務(wù)器端的HTML腳本/編程語(yǔ)言,是一種簡(jiǎn)單的渴庆、面向?qū)ο?..
    廖馬兒閱讀 2,137評(píng)論 2 38