资讯专栏INFORMATION COLUMN

xhprof的使用

darryrzhong / 3230人阅读

摘要:它报告函数级别的请求次数和各种指标,包括阻塞时间,时间和内存使用情况。它独有的数据计算的报告后处理阶段。在数据收集时,通过检测循环来处理递归的函数调用,并通过给递归调用中每个深度的调用一个有用的命名来避开死循环。

简介

XHProf是一个分层PHP性能分析工具。
XHProf是一个分层PHP性能分析工具。它报告函数级别的请求次数和各种指标,包括阻塞时间,CPU时间和内存使用情况。一个函数的开销,可细分成调用者和被调用者的开销,XHProf数据收集阶段,它记录调用次数的追踪和包容性的指标弧在动态callgraph的一个程序。它独有的数据计算的报告/后处理阶段。在数据收集时,XHProfd通过检测循环来处理递归的函数调用,并通过给递归调用中每个深度的调用一个有用的命名来避开死循环。XHProf分析报告有助于理解被执行的代码的结构,它有一个简单的HTML的用户界面( PHP写成的)。基于浏览器的性能分析用户界面能更容易查看,或是与同行们分享成果。也能绘制调用关系图。(来自百度百科)

前提

我的PHP版本是PHP7:

而xhprof支持PHP7的库请在longxinH-xhprof查看。

备注:我之前在phacility克隆的,不过安装失败,原因就是我的PHP版本是PHP7,而phacility版本的并不支持。(采坑呢~~)

安装步骤

当做一个php项目!clone别人php代码放哪个目录你自己定
1.编译安装

cd /Users/birjemin/Developer/Php
git clone https://github.com/longxinH/xhprof
cd xhprof/extension
phpize
./configure
make
make install

2.配置文件

cd /usr/local/etc/php/7.0/conf.d
vim ext-xhprof.ini

添加内容(这个就是编译成功之后的路径,见上图)

[xhprof]
extension="/usr/local/Cellar/php70/7.0.14_7/lib/php/extensions/no-debug-non-zts-20151012/xhprof.so"

3.重启php-fpm(视个人重启方式而定,我的重启方式是这样的)

cd /usr/local/etc/php/7.0/
sudo killall php-fpm
sudo /usr/local/Cellar/php70/7.0.14_7/sbin/php-fpm -D

4.查看是否安装成功

恭喜安装成功!

使用步骤

1.如果使用呢?两种方法,第一种就是把xhprof_lib.php和xhprof_runs.php拷贝到项目中,第二种就是用绝对路径引入这两个文件,推荐第一种,这样别人clone的你的项目,不需要做啥。

2.建立两个开启函数(isDev()是判断本地环境的意思,请视情况删除)

开启xhprof

function enableXhprof()
{
    isDev() && xhprof_enable(0, []);
}

运行xhprof(xhprof_lib.php和xhprof_runs.php可以拷贝到项目的,请确保include_once请够加载这两个文件)。

function disableXhprof()
{
    if (isDev()) {
        $xhprof_data = xhprof_disable();
        include_once app_path() . "/xhprof_lib.php";
        include_once app_path() . "/xhprof_runs.php";
        $xhprof_runs = new XHProfRuns_Default();
        $run_id = $xhprof_runs->save_run($xhprof_data, "xhprof_foo");
        #echo $run_id;
    }
}

3.可以在需要监听的接口中代码片段前面加上enableXhprof(),后面加上disableXhprof()就好了。接下来就可以分析这段代码了。(请确保这两个函数全局访问)

4.将克隆的xprof配置虚拟主机,这个和你的项目一样的,就把xprof也当做一个项目,配置成浏览器可访问。比如我的配置:

host: 127.0.0.1 local.xhprof.com

nginx server conf

server {
  listen       80;
  server_name  local.xhprof.com;
  access_log   logs/xhprof.access.log  main;
  autoindex on;
  location / {
    root  /Users/birjemin/Developer/Php/xhprof;
    index  index.html index.htm index.php;
    try_files $uri $uri/ /index.php?$query_string;
  }
  location ~ .php$ {
    root           /Users/birjemin/Developer/Php/xhprof;
    fastcgi_pass   127.0.0.1:9000;
    fastcgi_index  index.php;
    fastcgi_param  SCRIPT_FILENAME $document_root$fastcgi_script_name;
    fastcgi_intercept_errors    on;
    include        fastcgi_params;
  }
}

5.重启nginx,浏览器访问local.xhprof.com看看能不能访问(没有目录??你是不是浏览器无法访问目录??权限没开。。自己配置一下)

6.在postman或者浏览器访问接口,转啊转,好了之后就可以去
http://local.xhprof.com/xhprof_html/查看了。(图我就不截了。。下次讲一下xgui的使用)

遇到的问题

1.php -v的版本和phpinfo()的版本不一致,如下图:

解决方法:更改php cli的默认版本

我用的是bash

vim .bash_profile

添加两行

# PHP -v
export PATH="/usr/local/Cellar/php70/7.0.14_7/bin:$PATH"

生效

source .bash_profile

2.编译成功,但是php -m 没有 xhprof。

xhprof支持PHP7的库请在longxinH-xhprof查看!!!!

备注

全程经历了2.5h吧~~~不过文章也写了2.5h。哈哈哈哈~这个东西和xdebug不一样的,这个是分析性能瓶颈的,可以让你优化代码。xdebug主要用于调试,我下次写一个xdebug安装的过程。

参考

https://www.jianshu.com/p/38e3ae81970c

https://juejin.im/post/5860d23f128fe10069e1cfbf

http://blog.csdn.net/qq_28602957/article/details/72697901

https://baike.baidu.com/item/xhprof/2513363?fr=aladdin

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/28279.html

相关文章

  • 使用XHProf分析PHP性能瓶颈(一)

    摘要:输出的性能数据中添加数据。中间是要分析的代码。是一个绘制图形的工具,可以更为直观的让你查看性能的瓶颈。这样所有使用该环境的都会生效。这样仅该项目生效。 安装xhprof扩展 wget http://pecl.php.net/get/xhprof-0.9.4.tgz tar zxf xhprof-0.9.4.tgz cd xhprof-0.9.4/extension/ sudo phpi...

    pkwenda 评论0 收藏0
  • 使用XHProf查找PHP性能瓶颈

    摘要:是开发的一个测试性能的扩展,本文记录了在应用中使用对进行性能优化,查找性能瓶颈的方法。函数用于停止性能分析,并返回分析的数据。该参数用于为剖析结果添加额外的信息,该参数的值使用以下宏,如果需要提供多个值,使用进行分隔。 XHProf是facebook 开发的一个测试php性能的扩展,本文记录了在PHP应用中使用XHProf对PHP进行性能优化,查找性能瓶颈的方法。 安装Xhprof扩展...

    Xufc 评论0 收藏0
  • PHP性能测试工具xhprof安装和使用

    摘要:最近要做网站的性能对比,于是就找一款性能测试工作来玩玩,工具很多,但相比之前还是觉得的安装和使用相对来说简单点,数据分析也都还可以,下面就说说它的安装和使用。。。 最近要做网站的性能对比,于是就找一款性能测试工作来玩玩,工具很多,但相比之前还是觉得xhprof的安装和使用相对来说简单点,数据分析也都还可以,下面就说说它的安装和使用。。。 下载xhprof和graphviz ...

    FleyX 评论0 收藏0
  • PHP 性能追踪及分析工具(XHPROF

    摘要:什么是开源的轻量级性能分析工具。它报告函数级别的请求次数和各种指标,包括阻塞时间,时间和内存使用情况。基于浏览器的性能分析用户界面能更容易查看,或是与同行们分享成果。对于本地开发环境来说,进行性能分析是够用了。 什么是 XHPROF? XHPROF:Facebook 开源的轻量级PHP性能分析工具。 它报告函数级别的请求次数和各种指标,包括阻塞时间,CPU时间和内存使用情况。 XHPr...

    raoyi 评论0 收藏0
  • LNMP部署laravel与xhprof安装使用

    摘要:重启启动项目中配置启动性能分析器需要测试的内容停止性能分析器根据自己安装的写的路径 整个过程部署laravel与xhprof安装 前提成功安装了LNMP集成环境 (lnmp.org 即可快速安装),保证network正常运行 首先配置laravel的运行环境 1.上传代码到/home/wwwroot/default/2.修改nginx配置文件的root以及rewrite配置 #root...

    tinysun1234 评论0 收藏0
  • LNMP部署laravel与xhprof安装使用

    摘要:重启启动项目中配置启动性能分析器需要测试的内容停止性能分析器根据自己安装的写的路径 整个过程部署laravel与xhprof安装 前提成功安装了LNMP集成环境 (lnmp.org 即可快速安装),保证network正常运行 首先配置laravel的运行环境 1.上传代码到/home/wwwroot/default/2.修改nginx配置文件的root以及rewrite配置 #root...

    yiliang 评论0 收藏0

发表评论

0条评论

darryrzhong

|高级讲师

TA的文章

阅读更多
最新活动
阅读需要支付1元查看
<