当前位置:博客首页>>PHP >> 阅读正文

使用xdebug+webgrind分析php性能

作者: 郑晓 分类: PHP 发布于: 2017-12-29 19:07 浏览:5,318 评论(2)


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() 看看是否加载成功

下载webgrind,Github:https://github.com/jokkedk/webgrind

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

       

本文采用知识共享署名-非商业性使用 3.0 中国大陆许可协议进行许可,转载时请注明出处及相应链接。

本文永久链接: https://www.zh30.com/xdebug-webgrind.html

使用xdebug+webgrind分析php性能:目前有2 条留言

用户评论头像 123发表于 2018年01月05日 12:10[回复]

不错

console.log(222);

用户评论头像 123发表于 2018年01月05日 12:05[回复]

666

发表评论

change vcode