linux php 瓶颈分析,Ubuntu下使用Xdebug分析PHP程序的瓶颈

经济学中有一条著名的80-20定律,引用到编程中,就是:80%的性能瓶颈是由20%的代码引起的。

Ubuntu下借助PHP的XDebug扩展,可以有效地找出这20%的代码。

一、安装配置

1、下载PHP的XDebug扩展,网址:http://xdebug.org/

2、在Ubuntu下编译安装XDebug

sudo tar vxf xdebug-2.1.0.tgz cd xdebug-2.1.0.tgz

sudo /usr/local/php/bin/phpize

sudo ./configure --enable-xdebug --with-php-config=/usr/local/php/bin/php-config

sodu make && make install

注:安装完成之后在/usr/local/php/lib/php/extension/no-debug-non-zts-20090626下会有一个 xdebug.so 文件

sodu vim /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

sudo mkdir -p /tmp/xdebug

sudo chmod 777 /tmp/xdebug

sudo chown group:user /tmp/xdebug

sudo /usr/local/apache/bin/apachectl -k restart

此时,xdebug应该已经配置成功了,可以使用<?php phpinfo(); ?>来查看php信息,如果有xdebug这么一栏,则说明安装成功。

这时,每当使用web浏览器访问一次php文件,就会产生一个相应时间戳的log文件,可以查看它记录的信息。

我使用的log分析软件是WinCacheGrind,因为是windows版,所以需要使用wine启动。

接下来,进入WinCacheGrind就能看到每个函数执行的时间了~0b1331709591d260c1c78e86d0c51c18.png

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值