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图像方式查看整个调用树,对于要查找系统哪个位置执行慢的问题非常给力。