PHP效能分析工具xhprof的安裝使用與相關的注意事項

來源:互聯網
上載者:User
xhprof 是一款Facebook工程師開發和維護的一款PHP效能分析、調試工具,相較於xdebug要更輕量,更節省資源,強烈推薦大家使用。下面這篇文章主要給大家介紹了關於PHP效能分析工具xhprof的安裝與使用方法的相關資料,需要的朋友可以參考下。

前言

xhprof由facebook開源出來的一個PHP效能監控工具,佔用資源很少,甚至能夠在生產環境中進行部署。

它可以結合graphviz使用,能夠以圖片的形式很直觀的展示代碼執行耗時。

下面主要講一下安裝和使用過程

1、安裝

(1)下載和解壓

wget http://pecl.php.net/get/xhprof-0.9.4.tgztar zxvf xhprof-0.9.4.tgz

(2)編譯和運行

cd xhprof-0.9.4/extension/phpize //此語句編譯PHP擴充的工具,主要是根據系統資訊產生對應的configure檔案,一般存放在/usr/local/php/bin/目錄下./configure --with-php-config=/usr/local/php/bin/php-configmake && make installmkdir /tmp/xhprof

(3)編輯php.ini:

[xhprof]extension = xhprof.soxhprof.output_dir=/tmp/xhprof

xhprof.output_dir是分析組建記錄檔的儲存路徑

(4)安裝外掛程式

最後返回數組,就表示安裝好了。具體哪些值是什麼意思先別管,因為下面有UI的配置。會很直觀!

yum -y install libjpeg freetype freetype-devel libjpeg-devel liberation-sans-fonts.noarch

自動安裝

yum -y install graphviz

(5)插入代碼

//找到你要分析的代碼,在代碼開始處添加,start profiling,將會統計記憶體佔用情況xhprof_enable(XHPROF_FLAGS_MEMORY);//具體代碼//在代碼結束位置添加$xhprof_data = xhprof_disable(); // stop profiler, display raw xhprof data for the profiler runinclude_once ("/usr/local/src/xhprof-0.9.4/xhprof_lib/utils/xhprof_lib.php"); # 請注意佈建網站 include_path 許可權include_once ("/usr/local/src/xhprof-0.9.4/xhprof_lib/utils/xhprof_runs.php");$xhprof_runs = new \XHProfRuns_Default();// Save the run under a namespace "xhprof_foo".// **NOTE**:// By default save_run() will automatically generate a unique// run id for you. [You can override that behavior by passing// a run id (optional arg) to the save_run() method instead.]$xhprof_runs->save_run($xhprof_data, "xhprof_foo");

(6)查看

給(2)中的xhprof-0.9.4/xhprof_html 配置一個可以訪問的網站,可以簡潔的使用php內建的server

cd xhprof-0.9.4/xhprof_htmlphp -S 0.0.0.0:8990

然後訪問ip+連接埠就可以報告了。

2、使用說明

  • Function Name:方法名稱。

  • Calls:方法被調用的次數。

  • Calls%:方法調用次數在同級方法總數調用次數中所佔的百分比。

  • Incl.Wall Time(microsec):方法執行花費的時間,包括子方法的執行時間。(單位:微秒)

  • IWall%:方法執行花費的時間百分比。

  • Excl. Wall Time(microsec):方法本身執行花費的時間,不包括子方法的執行時間。(單位:微秒)

  • EWall%:方法本身執行花費的時間百分比。

  • Incl. CPU(microsecs):方法執行花費的CPU時間,包括子方法的執行時間。(單位:微秒)

  • ICpu%:方法執行花費的CPU時間百分比。

  • Excl. CPU(microsec):方法本身執行花費的CPU時間,不包括子方法的執行時間。(單位:微秒)

  • ECPU%:方法本身執行花費的CPU時間百分比。

  • Incl.MemUse(bytes):方法執行佔用的記憶體,包括子方法執行佔用的記憶體。(單位:位元組)

  • IMemUse%:方法執行佔用的記憶體百分比。

  • Excl.MemUse(bytes):方法本身執行佔用的記憶體,不包括子方法執行佔用的記憶體。(單位:位元組)

  • EMemUse%:方法本身執行佔用的記憶體百分比。

  • Incl.PeakMemUse(bytes):Incl.MemUse峰值。(單位:位元組)

  • IPeakMemUse%:Incl.MemUse峰值百分比。

  • Excl.PeakMemUse(bytes):Excl.MemUse峰值。單位:(位元組)

  • EPeakMemUse%:Excl.MemUse峰值百分比。

注意:

1、在正式啟用前,一定要確認不會影響正常的資料輸出。確認輸出內容無異後,再上線。

2、每個url的max_time不要設定的過小。

3、xhprof會影響線上服務的效能,因此最好只在一台機器上進行監控,或者 修改xhprof.php代碼,對請求進行隨機監控。

總結

您可能感興趣的文章:

php封裝db類串連sqlite3資料庫的方法執行個體講解

PHP實現類比http請求的方法分析講解

php實現socket推送技術的樣本講解

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.