使用xdebug+webgrind分析php性能

xdebug是php的一个调试工具扩展,webgrind是一个通过web可视化方式来查看xdebug日志的工具,两个加起来,对于查找PHP整个系统中的性能瓶颈非常有用。
安装xdebug:https://xdebug.org/download.php 根据自己php版本选择和下载对应的xdebug

# wget http://xdebug.org/files/xdebug-2.4.1.tgz
# tar zxf xdebug-2.4.1.tgz
# cd xdebug-2.4.1

开始编译xdebug.so文件,注意自己phpize和php-config的位置,可使用whereis查找

# /data/php/bin/phpize
# ./configure --with-php-config=/data/php/bin/php-config
# make && make install

编译安装后.so文件在当前目录中的modules目录中,可以放这也可以移走。

配置php.ini

zend_extension="/data/php/lib/php/extensions/xxxxxxx/xdebug.so"
[xdebug]
xdebug.profiler_append=0
xdebug.profiler_output_name="cachegrind.out.%R%u"
xdebug.profiler_enable=On
xdebug.profiler_output_dir="/data/xdebug/"
xdebug.profiler_enable_trigger=On

注意xdebug的so需要使用zend_extension引入,后面写绝对路径
其它配置信息自行查询
重启php-fpm

# kill -INT `cat /data/php/run/php-fpm.pid`
# /data/php/sbin/php-fpm

访问phpinfo() 看看是否加载成功

浏览器中直接访问QQ购买webgrind即可,webgrind自动遍历xdebug所配置的日志目录,可显示每一步的调试耗时、耗时占比,也可以直接查看调用所在的代码位置,服务器安装了dot的话( sudo apt-get install graphviz ),也可以点击“show call graph”按钮以svg图像方式查看整个调用树,对于要查找系统哪个位置执行慢的问题非常给力。

上一篇:Windows 配置 Xdebug 进行动态调试


下一篇:Java远程断点调式