php 性能分析工具 xhprof 使用

1. 環境

CentOS 7
nginx 1.14
php 5.6

2. xhprof 版本

xhprof-0.9.4

圖形展示依賴:
graphviz
graphviz-gd
libpng

3. 安裝 xhprof

下載 xhprof-0.9.4.tgz
tar xvzf xhprof-0.9.4.tgz
cd xhprof-0.9.4/extension
執行  /usr/local/php-fpm/bin/phpize
./configure  --with-php-config=/usr/local/php-fpm/php-config
make && make install

然後,在 php.ini 中添加 xhprof.so

vim  /usr/local/php-fpm/etc/php.ini
添加:
[xhprof]
extension=xhprof.so
xhprof.output_dir="/data/wwwroot/xhprof/output"

記得要創建 xhprof.output_dir 目錄,給777 權限;
簡單測試:

重啓一下 php-fpm: /etc/init.d/php-fpm  restart ;
測試一下 xhprof.so 是否加載成功:
/usr/local/php-fpm/bin/php -m  | grep  xhprof

4. 爲 xhprof 添加 nginx 虛擬機

在 nginx 虛擬機目錄增加一個 server:


server {
        listen  80;
        server_name xhprof.dev;
        root /data/wwwroot/xhprof;
        index index.php index.html;
        access_log /data/logs/nginx/xhprof/xhprof.dev.log custom;
        error_log /data/logs/nginx/xhprof/xhprof.dev.log.err error;
        rewrite_log on;

        location ~* \.php$ {
           #fastcgi_pass   127.0.0.1:9000;
            fastcgi_pass   unix:/usr/local/php-fpm/run/php-fpm-www.sock;
            fastcgi_index  index.php;
            fastcgi_param  SCRIPT_FILENAME  $document_root$fastcgi_script_name;
            include        fastcgi_params;
        }
}

注意:

  • server_name 根據實際情況;
  • root 根據實際情況;
  • 創建日誌文件路徑;
  • fastcgi_pass 根據實際情況而定;

5. 測試 xhprof web

將 xhprof-0.9.4 目錄下 xhprof_html 和 xhprof_lib 兩個目錄移動或者複製到 web 的 root 路徑 /data/wwwroot/xhprof :

cp  -r /usr/local/src/xhprof-0.9.4/xhprof_html /data/wwwroot/xhprof/xhprof_html
cp  -r /usr/local/src/xhprof-0.9.4/xhprof_lib /data/wwwroot/xhprof/xhprof_lib

創建 xhprof 測試文件

cd  /data/wwwroot/xhprof/

vim  test.php

<?php

//加載所需文件
include_once "./xhprof_lib/utils/xhprof_lib.php";
include_once "./xhprof_lib/utils/xhprof_runs.php";

//隨意定義一個函數
function test($max)
{
    for ($idx = 0; $idx < $max; $idx++) {
        echo '';
    }
}

//定義測試方法
function a()
{
    test(rand(1000,5000));
}

//開始分析
xhprof_enable();

//需要分析的函數
a();

//結束分析
$xhprof_data = xhprof_disable();
//實例化xhprof類
$xhprof_runs = new XHProfRuns_Default();
//獲取當前當前頁面分析結果
$run_id = $xhprof_runs->save_run($xhprof_data, "xhprof_foo");

echo "\nhttp://xhprof.dev/xhprof_html/index.php?run=$run_id&source=xhprof_foo\n";

測試:
在瀏覽器訪問 http://xhprof.dev/test.php 結果:

php 性能分析工具 xhprof 使用

可以看到,返回了一個帶run_id 的 url,通過這個 url 再跳轉訪問就可以看到具體的測試結果了:

php 性能分析工具 xhprof 使用

如果想查看圖像,可以點擊 [View Full Callgraph] :

php 性能分析工具 xhprof 使用

注意:

一般,大家安裝完之後,系統還不能馬上畫圖,一般會報錯:

Format: "png" not recognized. Use one of: canon cmap cmapx cmapx_np dot dot_json eps fig gv imap imap_np ismap json json0 mp pic plain plain-ext pov ps ps2 svg svgz tk vml vmlz xdot xdot1.2 xdot1.4 xdot_json

解決辦法:

需要安裝一些依賴的工具

yum  install  graphviz
yum  install  libpng
yum  install  graphviz-gd (剛開始我沒有安裝這個,總是報錯)

6. 總結

以上的內容只是簡單安裝使用 xhprof 工具,要真正用來測試 php 的性能,還需要再 php 代碼中使用,如何添加結合,以後再研究。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章