用xdebug分析PHP以及结果分析程序webgrind的使用

本文详细介绍了如何在PHP项目中利用xdebug扩展和webgrind工具来跟踪并分析代码执行过程中的性能瓶颈,通过配置php.ini文件启用性能分析,生成结果文件,并使用webgrind读取和展示这些数据,从而直观地识别出哪些部分的代码执行速度较慢,进而优化代码效率。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

我们在做项目的时候,经常需要编写大量的PHP代码,有很多的方法以及变量,当项目进行到一定程度,代码越来越多,你会发现程序变慢,但有时我们不知道具体是哪块代码执行慢,或者哪个方法占用了太长的执行时间,这时我们就需要一个调试工具,来帮我们记录程序执行过程中的一些具体信息,包括类、方法名、执行时间、次数等信息,今天介绍的工具是xdebug以及他的结果分析展示工具webgrind。
 
    xdebug是在PHP安装包中内置的,具体路径是ext/php_xdebug.dll,由于内置,所以我们不需要重新安装,只需要修改配置文件php.ini来启用该库,打开php.ini文件,并查找修改以下配置信息:

      zend_extension = "c:\xampp\php\ext\php_xdebug.dll"
      配置php_xdebug.dll的地址,去掉前面的;号
      xdebug.default_enable = On
      去掉;号,启用该功能
      xdebug.profiler_append = 0
      分析结果文件是否重写配置项,0为不重写,新的分析结果会追加到上一次结果分析之后 1为重写,生成新的结果文件,去掉;号
      xdebug.profiler_enable = 0
      性能分析配置项,如果值为1,该功能自动生成结果分析文件,去掉;号
      xdebug.profiler_enable_trigger = 1
      需要触发的性能分析配置项,值设为1,需要在访问地址后面加XDEBUG_PROFILE才会生成结果文件
      xdebug.profiler_output_dir = "tmp/xdebug"
      结果文件生成路径,默认是tmp文件夹,如果修改了配置,xdebug文件夹需要我们手动建立
     
      配置信息修改完成,保存php.ini,然后重启apache服务。

      我们可以访问本地的info.php文件,具体访问方式:
      http://localhost/info.php?XDEBUG_PROFILE
      然后我们可以看到在tmp/xdebug文件夹下面生成了结果文件,cachegrind.out.**** *为整形数字
      我们可以用webgrind去读取该结果,并生成直观的分析结果。
     
      webgrind获取地址: https://github.com/jokkedk/webgrind/downloads
      下载之后解压,将解压的文件夹复制到你的apache/htdocs里,然后访问,可以看到我们刚才生成的结果文件,点击update可以得到直观的分析结果。
      用xdebug分析PHP以及结果分析程序webgrind的使用

      webgrind分析结果参数说明:
      分析结果包括了页面执行过程中所访问的方法,函数以及required/include包含的文件。
      InvocationCount 方法被执行的次数
      Total SelfCost  执行该过程/方法的时间,不包括方法内调用执行其他的自定义函数的时间
      TotalInclusive Cost 方法执行的总时间,包括方法内调用的其他方法的执行时间
      Calls执行过程中调用的方法/函数
      Total CallCost 执行所有的调用函数/方法的时间总计
      Count方法被调用的次数

      关于不同的颜色的说明:蓝色代表PHP内置函数所占耗费时间的比例,绿色是自定义函数所占耗费时间的比例,灰色是required/include所占耗费时间的比例,黄色是过程执行所占时间的比例
     
      通过该工具我们可以很直观的看到某个方法,某个过程所花费的时间,可以分析出程序的瓶颈在哪里。

安装 xdeubg zend 扩展
# yum install php-pecl-xdebug
配置 php.d/xdebug.ini
# vi /etc/php.d/xdebug.ini
; 加入以下内容
; profiler
xdebug.profiler_enable=1
xdebug.profiler_enable_trigger=1
xdebug.profiler_output_dir=/tmp/xdebug
xdebug.profiler_output_name=cachegrind.out.%p

; trace
xdebug.auto_trace=1
xdebug.show_exception_trace=1
xdebug.trace_output_dir=/tmp/xdebug
xdebug.trace_output_name=trace.%c

注:需手工创建 /tmp/xdebug 目录且所属用户应为 php-fpm 配置文件中的 user 用户。配置完毕,重启 service php-fpm restart

下载 webgrind
$ cd /var/www/html/
$ git clone git://github.com/jokkedk/webgrind.git
安装 graphviz
# yum install graphviz

graphviz 附带 dot 命令用于下文的配置。

使用 webgrind

webgrind v1.1 的版本增加了 Show Call Graph 按钮,依赖 python dot 命令,类似 xhprof 的 View Full Callgraph 绘制程序调用流程图功能,相对于 xhprof 较简洁。更多 xhprof 信息请查看 使用 XHProf 分析你的 PHP 程序

配置 webgrind 的绘制流程图功能,查看 pythondot 命令位置which python which dot,编辑 webgrind/config.php,将$pythonExecutable = '/usr/bin/python'$dotExecutable = '/usr/bin/dot'替换为刚查到相应路径。

在浏览器访问任意一个项目路径,/tmp/xdebug 目录下会生成一个 cachegrind.out.xxxxx文件作为 webgrind 的数据来源,打开 webgrind 页面,如:http://localhost/webgrind/,点击右上角 update 按钮即会分析最后一次访问的项目地址的 PHP 程序,可以通过选择第二个下拉框中的地址来分析相应的程序,点击 Show Call Graph 按钮就会显示当前分析的程序的简明调用流程图。

表格中后三列的含义:

Invocation Count:函数调用次数
Total Self Cost:函数本身花费的时间
Total Inclusive Cost:包含内部函数花费的时间
简析 webgrind 生成流程图

webgrind 生成流程图使用源码下的 library/gprof2dot.py python 脚本,先将 cachegrind.out.xxxxx 转换成 DOT,再使用 dot 命令转换成图片输出。

PHP 使用 shell_exec 函数执行:

/usr/bin/python library/gprof2dot.py -n 10 -f callgrind /tmp/xdebug/cachegrind.out.xxxxx | /usr/bin/dot -Tpng -o /tmp/xdebug/cachegrind.out.xxxxx-10.webgrind.png
转载请注明出处。
本文地址:http://blog.aboutc.net/php/18/php-profiler-xdebug-webgrind

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值