PHP性能被動(dòng)分析工具之xhgui加tideways的安裝實(shí)踐

PHP性能被動(dòng)分析工具之xhgui加tideways的安裝實(shí)踐

By:0x584A Date:2016-11-23 17:55:42

前言

最近一直想做個(gè)接口信能分析康栈,但是手動(dòng)打log實(shí)在能把人給累死薪夕。怎么辦呢股耽?想到之前有寫過一篇我所知道的PHP相關(guān)調(diào)優(yōu)匯總巧婶,里面有一個(gè)Xdebug + kcachegrind的調(diào)優(yōu)方式贪染。 但是呢越走,每次都需要將它產(chǎn)生的cachegrind.out.*文件下到本地棚品,再用kcachegrind打開做分析,而且體驗(yàn)感也不是特別好(原諒我英語(yǔ)不過三的渣渣...)

性能分析的UI組合

  • uprofiler 點(diǎn)擊下載
  • xhprof + xhprof.io 【年久失修用uprofiler替換即可或用修復(fù)板廊敌,但支持保存分析數(shù)據(jù)至mysql铜跑,函數(shù)調(diào)用記錄完整,內(nèi)核級(jí)別函數(shù)都能顯示骡澈,支持域名索引】修復(fù)板下載
  • xhprof or uprofiler or tideways + xhgui 【推薦锅纺,保存數(shù)據(jù)至MongoDB,UI界面友好肋殴,有中文UI版伞广,不支持域名索引對(duì)于線上調(diào)試支持較差】中文版下載拣帽,英文原版下載
  • tideways【推薦,這個(gè)最絢的而且一直在持續(xù)維護(hù)嚼锄。但是使用它酷炫的UI需要付費(fèi)减拭,擴(kuò)展則不需要∏螅】tideways下載地址

安裝

  • 環(huán)境

    • tideways + xhgui
    • php>5.5
    • mongodb
    • php5-mcrypt
    • apt-get install libcurl4-openssl-dev libpcre3-dev
  1. 安裝mongodb

前置需安裝php-devsudo apt-get install php5-dev

$ sudo pecl install mongodb
 $ cd /etc/php5/mods-available
 $ sudo sh -c "echo 'extension=mongodb.so' > /etc/php5/mods-available/mongodb.ini"
 [sudo] 0x584A 的密碼:
 $ cd ../fpm/conf.d
 $ sudo ln -s ../../mods-available/mongodb.ini 20-mongodb.ini
 $ sudo service php5-fpm restart
 $ sudo apt-get install mongodb -y
  1. 安裝xhgui
$ git clone https://github.com/maxincai/xhgui.git
 $ cd xhgui
 $ php install.php

加索引

$ mongo
 > use xhprof
 > db.results.ensureIndex( { 'meta.SERVER.REQUEST_TIME' : -1 } )
 > db.results.ensureIndex( { 'profile.main().wt' : -1 } )
 > db.results.ensureIndex( { 'profile.main().mu' : -1 } )
 > db.results.ensureIndex( { 'profile.main().cpu' : -1 } )
 > db.results.ensureIndex( { 'meta.url' : 1 } )
  1. 安裝tideways

見該安裝地址拧粪,選擇系統(tǒng)安裝方式https://tideways.io/profiler/docs/setup/installation

  • 需要在nginx應(yīng)用中加入fastcgi_param TIDEWAYS_SAMPLERATE "25";
  • 需要在nginx應(yīng)用中加入fastcgi_param PHP_VALUE "auto_prepend_file=/home/0x584A/www/xhgui/external/header.php";
  1. ngxin應(yīng)用配置

    應(yīng)用

    server {
        listen 127.0.10.1:80;
        server_name  app.com;
        root   /home/0x584A/www/app;
        index  index.html index.htm index.php;
    
        location / {
            if (!-e $request_filename) {
                rewrite ^(.*)$ /index.php?$1 last ;
                break;
            }
        }
    
        location ~ ^(.+\.php)(.*)$ {
            fastcgi_pass 127.0.0.1:9000;
            fastcgi_index   index.php;
            fastcgi_split_path_info         ^(.+\.php)(.*)$;
            fastcgi_param TIDEWAYS_SAMPLERATE "25";
             fastcgi_param PHP_VALUE "auto_prepend_file=/home/0x584A/www/xhgui/external/header.php";
            fastcgi_param       PATH_INFO                $fastcgi_path_info;
            fastcgi_param       PATH_TRANSLATED        $DOCUMENT_ROOT$fastcgi_path_info;
            fastcgi_param       SCRIPT_FILENAME  $DOCUMENT_ROOT/$fastcgi_script_name;
            include             fastcgi_params;
        }
    }
    

    xhgui

    server {
            listen 127.0.10.2:80;
            server_name  debug.com;
            root   /home/0x584A/www/xhgui/webroot;
            index  index.html index.htm index.php;
    
        location / {
            try_files $uri $uri/ /index.php?$uri&$args;
        }
    
        location ~ \.php$ {
            try_files $uri =404;
            include /etc/nginx/fastcgi_params;
            fastcgi_pass    127.0.0.1:9000;
            fastcgi_index   index.php;
            fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
        }
    }
    
    

    訪問配置好的頁(yè)面即可。

注意

  • 分析方式請(qǐng)自行更具url設(shè)置

    'profiler.enable' => function() {
        // url 中包含debug=1則百分百捕獲
        if(!empty($_GET['debug'])){
            return True;
        }else{
            // 1%采樣
            return rand(1, 100) === 42;
        }
    },
    
  • 在xhgui的config/config.default.php中沧侥,可設(shè)置采樣命中次數(shù)可霎;

    • return rand(1, 100) === 42;1%的采樣率,改成return True;則標(biāo)識(shí)每次都采樣
  • 分析參數(shù)過多則清除mongodb數(shù)據(jù)

    $ mongo
      $ use xhprof;
      $ db.dropDatabase();
    

終極特效

1.png
2.png
3.png

參考

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末宴杀,一起剝皮案震驚了整個(gè)濱河市癣朗,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌旺罢,老刑警劉巖旷余,帶你破解...
    沈念sama閱讀 217,084評(píng)論 6 503
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異扁达,居然都是意外死亡正卧,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,623評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門跪解,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)炉旷,“玉大人,你說我怎么就攤上這事叉讥【叫校” “怎么了?”我有些...
    開封第一講書人閱讀 163,450評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵图仓,是天一觀的道長(zhǎng)抽高。 經(jīng)常有香客問我,道長(zhǎng)透绩,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,322評(píng)論 1 293
  • 正文 為了忘掉前任壁熄,我火速辦了婚禮帚豪,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘草丧。我一直安慰自己狸臣,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,370評(píng)論 6 390
  • 文/花漫 我一把揭開白布昌执。 她就那樣靜靜地躺著烛亦,像睡著了一般诈泼。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上煤禽,一...
    開封第一講書人閱讀 51,274評(píng)論 1 300
  • 那天铐达,我揣著相機(jī)與錄音,去河邊找鬼檬果。 笑死瓮孙,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的选脊。 我是一名探鬼主播杭抠,決...
    沈念sama閱讀 40,126評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼恳啥!你這毒婦竟也來(lái)了偏灿?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 38,980評(píng)論 0 275
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤钝的,失蹤者是張志新(化名)和其女友劉穎翁垂,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體扁藕,經(jīng)...
    沈念sama閱讀 45,414評(píng)論 1 313
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡沮峡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,599評(píng)論 3 334
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了亿柑。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片邢疙。...
    茶點(diǎn)故事閱讀 39,773評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖望薄,靈堂內(nèi)的尸體忽然破棺而出疟游,到底是詐尸還是另有隱情,我是刑警寧澤痕支,帶...
    沈念sama閱讀 35,470評(píng)論 5 344
  • 正文 年R本政府宣布颁虐,位于F島的核電站,受9級(jí)特大地震影響卧须,放射性物質(zhì)發(fā)生泄漏另绩。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,080評(píng)論 3 327
  • 文/蒙蒙 一花嘶、第九天 我趴在偏房一處隱蔽的房頂上張望笋籽。 院中可真熱鬧,春花似錦椭员、人聲如沸车海。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,713評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)侍芝。三九已至研铆,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間州叠,已是汗流浹背棵红。 一陣腳步聲響...
    開封第一講書人閱讀 32,852評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留留量,地道東北人窄赋。 一個(gè)月前我還...
    沈念sama閱讀 47,865評(píng)論 2 370
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像楼熄,于是被迫代替她去往敵國(guó)和親忆绰。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,689評(píng)論 2 354

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