Ubuntu下使用Xdebug可分析出PHP程序的瓶颈,具体内容如下所述。
经济学中有一条著名的80-20定律,引用到编程中,就是:80%的性能瓶颈是由20%的代码引起的。
Ubuntu下借助PHP的XDebug扩展,可以有效地找出这20%的代码。
一、安装配置
1、下载PHP的XDebug扩展,网址:http://xdebug.org/
2、在Ubuntu下编译安装XDebug
- sudotarvxfxdebug-2.1.0.tgzcdxdebug-2.1.0.tgz
- sudo/usr/local/php/bin/phpize
- sudo./configure--enable-xdebug--with-php-config=/usr/local/php/bin/php-config
- sodumake&&makeinstall
注:安装完成之后在/usr/local/php/lib/php/extension/no-debug-non-zts-20090626下会有一个xdebug.so文件
- soduvim/usr/local/php/lib/php.ini
修改php.ini,增加以下配置信息支持XDebug扩展
- zend_extension=/usr/local/php/lib/php/extensions/no-debug-non-zts-20090626/xdebug.so
- [Xdebug]
- xdebug.auto_trace=On
- xdebug.collect_params=On
- xdebug.collect_return=On
- xdebug.trace_output_dir="/tmp/xdebug"
- xdebug.profiler_enable=On
- xdebug.profiler_output_dir="/tmp/xdebug"
- xdebug.profiler_output_name="cachegrind.out.%c"
修改文件夹权限,使xdebug能够在指定文件夹中写log
- sudomkdir-p/tmp/xdebug
- sudochmod777/tmp/xdebug
- sudochowngroup:user/tmp/xdebug
- sudo/usr/local/apache/bin/apachectl-krestart
此时,xdebug应该已经配置成功了,可以使用来查看php信息,如果有xdebug这么一栏,则说明安装成功。
这时,每当使用web浏览器访问一次php文件,就会产生一个相应时间戳的log文件,可以查看它记录的信息。
我使用的log分析软件是WinCacheGrind,因为是windows版,所以需要使用wine启动。
接下来,进入WinCacheGrind就能看到每个函数执行的时间了~
总结:
希望本文介绍的在Ubuntu下使用Xdebug分析PHP程序的瓶颈的内容能够对读者有所帮助,更多有关linux系统的知识还有待于读者去探索和学习。
【编辑推荐】