Xdebug结合webgrind对程序进行性能分析 及 使用XHProf扩展测试php程序性能-排查PHP瓶颈

2024-07-03 1522阅读

一、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对程序进行性能分析 及 使用XHProf扩展测试php程序性能-排查PHP瓶颈

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

Xdebug结合webgrind对程序进行性能分析 及 使用XHProf扩展测试php程序性能-排查PHP瓶颈

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

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

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

Xdebug结合webgrind对程序进行性能分析 及 使用XHProf扩展测试php程序性能-排查PHP瓶颈

结果意义:

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";

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

Xdebug结合webgrind对程序进行性能分析 及 使用XHProf扩展测试php程序性能-排查PHP瓶颈

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

Xdebug结合webgrind对程序进行性能分析 及 使用XHProf扩展测试php程序性能-排查PHP瓶颈

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

Xdebug结合webgrind对程序进行性能分析 及 使用XHProf扩展测试php程序性能-排查PHP瓶颈

VPS购买请点击我

免责声明:我们致力于保护作者版权,注重分享,被刊用文章因无法核实真实出处,未能及时与作者取得联系,或有版权异议的,请联系管理员,我们会立即处理! 部分文章是来自自研大数据AI进行生成,内容摘自(百度百科,百度知道,头条百科,中国民法典,刑法,牛津词典,新华词典,汉语词典,国家院校,科普平台)等数据,内容仅供学习参考,不准确地方联系删除处理! 图片声明:本站部分配图来自人工智能系统AI生成,觅知网授权图片,PxHere摄影无版权图库和百度,360,搜狗等多加搜索引擎自动关键词搜索配图,如有侵权的图片,请第一时间联系我们,邮箱:ciyunidc@ciyunshuju.com。本站只作为美观性配图使用,无任何非法侵犯第三方意图,一切解释权归图片著作权方,本站不承担任何责任。如有恶意碰瓷者,必当奉陪到底严惩不贷!

目录[+]