Xdebug结合webgrind对程序进行性能分析 及 使用XHProf扩展测试php程序性能-排查PHP瓶颈
创始人
2025-01-15 00:36:55
0

一、Xdebug结合webgrind对程序进行性能分析

    Xdebug是一个开放源代码的PHP程序调试器,它的功能不只是把原来的纯文本错误展示变成了彩色的错误展示,还有实实在在地性能分析。

第一步:安装xdebug,php.ini中添加配置:

zend_extension = "E:/Lnmp/Bin/PHP/php-5.6.20-nts-x64/ext/php_xdebug.dll" xdebug.auto_trace = on xdebug.collect_params = on xdebug.collect_return = on xdebug.trace_output_dir = "E:/Lnmp/tmp"  xdebug.remote_enable = on xdebug.profiler_enable = on xdebug.profiler_enable_trigger = on xdebug.profiler_output_name = cachegrind.out.%t.%p xdebug.profiler_output_dir = "E:/Lnmp/tmp"

第二步:生成webgrind分析结果文件

    Xdebug加载正常后,在phpinfo()函数结果中能看到结果,这些都是次要的,现在我们运行任何一个网站后,注意查看xdebug.profiler_output_dir配置的目录下面的文件,会多了一些命名如cachegrind.out.1469499468.7924.webgrind的文件,如下图:

xdebug结合webgrind对程序进行性能分析

    这些就是我们需要用来做性能分析的文件,文件的命名是unix时间戳值和毫秒值组合的名字,如cachegrind.out.1469501182.6056。每请求一次就会生成一个文件,trace.4194868363.xt记录的是最新一次请求的数据,这时就需要使用我们的webgrind工具来进行分析了。webgrind也是一套PHP开发的程序,放在WEB目录下直接可以文件,里面有config.php进行相关的配置:

xdebug结合webgrind对程序进行性能分析

    如上图:defaultCostformat设置显示时间是用百分比还是用毫秒、微秒;defaultFunctionPercentage设置选出耗时之和占比大于百分之多少以上的程序进行性能分析(按用时大小序)。

第三步:图形化分析webgrind结果

    访问webgrind的页面(这时tmp目录下会生成文件cachegrind.out.1469501363.6056.webgrind)。选择分析的文件,点击update执行分析如下图(图中红框处即是读取配置值的地方):

xdebug结合webgrind对程序进行性能分析

结果意义:

1,看右上角的彩色条和列表中左边的颜色点是对应的,右上角是各颜色的总时间统计,列表是细分时间统计。其中绿色代表对类的调用;橙色代表其他过程调用;蓝色代表php内置函数,灰色代表require/include文件包含所用时间。

2,invocation count是php页面执行完毕函数被调用的总次数;total self cost 是函数自身耗时;total inclusive cost 函数从开始到执行完毕总耗时。

3,可点开每一项调用,查看更细的调用次数和调用用时统计。

二、使用XHProf扩展测试php程序性能-排查PHP性能瓶颈

    之前我简单使用过webgrind来对PHP程序的性能进行测试,今天推荐另一个性能测试工具:XHProf扩展。
    XHProf是Facebook开发的性能调试工具,能帮助直观的统计显示PHP程序执行中各方法函数调用次数和消耗时间,以方便我们排查性能瓶颈并进行调优。而更加方便的是,XHProf能绘制调用关系图。用时最长的执行流程会使用明显的粗线和颜色进行标识。对整个程序执行期间的流程和瓶颈一目了然,相比于XDeBug,XHProf是PHP的PECL扩展。比XDeBug更省资源,并且更加小巧。

    XHProf的安装:目前的最新版是0.9.4版

cd /usr/local/ wget http://pecl.php.net/get/xhprof-0.9.4.tgz tar zxvf xhprof-0.9.4.tgz cd xhprof-0.9.4/extension/ /usr/local/php/bin/phpize ./configure --with-php-config=/usr/local/php/bin/php-config  make && make install

安装就和安装其它的PHP扩展一样,完成后在php.ini中加入extension。不过除此之外还需要添加一项配置,如下:

extension=xhprof.so xhprof.output_dir="/tmp/xhprof"  #指定性能统计文件的存放目录

 重启php.使用也非常地简单:在整个程序的开头添加程序:

xhprof_enable();  #打开性能分析

    注意:因为分析过程需要加载一些xhprof已经写好的PHP程序,并且结果是以WEB形式的图表展现,所以需要调用一些xhprof已经写好的一些程序。在安装目录中有一个xhprof_lib目录和xhprof_html目录:在使用xhprof功能前需要将这两个目录放至WEB程序中(并列存放,并保证xhprof_html目录可以通过http访问),

    xhprof_lib目录:性能分析时需要加载的程序
    xhprof_html目录:WEB形式展现分析统计结果时要加载的程序

在整个程序的结尾添加:

#结束性能分析并获得性能数据:数组 $result = xhprof_disable(); #包含进分析程序 require 'xhprof_lib/utils/xhprof_lib.php'; require 'xhprof_lib/utils/xhprof_runs.php'; $xhprofRuns = new XHProfRuns_Default(); #保存性能分析文件,实际是一个数组数据serialize之后的结果 $runId = $xhprofRuns->save_run($result, 'test'); #生成分析页面的跳转URL $str = '/xhprof_html/index.php?run=' . $runId . '&source=test'; echo "phprof:$str";

 再次执行页面会在最后看到有如下链接:

点开链接能看到以表格展现的分析数据:

点击上面图中的 [View Full Callgraph]链接就能查看到图表分析结果:

相关内容

热门资讯

黑科技辅助!wpk辅助神器(透... 黑科技辅助!wpk辅助神器(透视)软件透明辅助挂(本来是真的有挂)-哔哩哔哩是一款可以让一直输的玩家...
5分钟了解“创思维正版辅助器下... 5分钟了解“创思维正版辅助器下载”详细透视开挂辅助安装-哔哩哔哩;一、创思维正版辅助器下载有挂的是的...
两分钟科普!wpk真吗,哈糖大... 两分钟科普!wpk真吗,哈糖大菠萝可以开挂吗,曝光教程(发现有挂)-哔哩哔哩哈糖大菠萝可以开挂吗辅助...
第一分钟了解(昆仑大厅)外挂辅... 第一分钟了解(昆仑大厅)外挂辅助插件(透视)详细教程(2022已更新)(哔哩哔哩);亲真的是有正版授...
黑科技辅助!wpk俱乐部长期盈... 黑科技辅助!wpk俱乐部长期盈利打法(透视)软件透明挂黑科技(切实存在有挂)-哔哩哔哩;1、让任何用...
第6分钟了解“功夫川嘛辅助器”... 第6分钟了解“功夫川嘛辅助器”详细透视开挂辅助器-哔哩哔哩;人气非常高,ai更新快且高清可以动的一个...
第五分钟辅助!xpoker辅助... 第五分钟辅助!xpoker辅助,德州透视插件,攻略教程(有挂方法)-哔哩哔哩德州透视插件辅助器中分为...
两分钟了解(皮皮跑胡子)外挂透... 两分钟了解(皮皮跑胡子)外挂透明挂辅助工具(辅助挂)透明挂教程(2020已更新)(哔哩哔哩);皮皮跑...
黑科技辅助!微扑克可以加入俱乐... 您好,微扑克可以加入俱乐部这款游戏可以开挂的,确实是有挂的,需要了解加微【136704302】很多玩...
8分钟了解“掌中乐游戏中心辅助... 8分钟了解“掌中乐游戏中心辅助器”详细透视开挂辅助脚本-哔哩哔哩;1、这是跨平台的掌中乐游戏中心辅助...