Ubuntu下如何使用Xdebug分析PHP程序的瓶頸?
Ubuntu下使用Xdebug可分析出PHP程序的瓶頸,具體內(nèi)容如下所述。
經(jīng)濟(jì)學(xué)中有一條著名的80-20定律,引用到編程中,就是:80%的性能瓶頸是由20%的代碼引起的。
Ubuntu下借助PHP的XDebug擴(kuò)展,可以有效地找出這20%的代碼。
一、安裝配置
1、下載PHP的XDebug擴(kuò)展,網(wǎng)址: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下會(huì)有一個(gè)xdebug.so文件
- soduvim/usr/local/php/lib/php.ini
修改php.ini,增加以下配置信息支持XDebug擴(kuò)展
- 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"
修改文件夾權(quán)限,使xdebug能夠在指定文件夾中寫(xiě)log
- sudomkdir-p/tmp/xdebug
- sudochmod777/tmp/xdebug
- sudochowngroup:user/tmp/xdebug
- sudo/usr/local/apache/bin/apachectl-krestart
此時(shí),xdebug應(yīng)該已經(jīng)配置成功了,可以使用來(lái)查看php信息,如果有xdebug這么一欄,則說(shuō)明安裝成功。
這時(shí),每當(dāng)使用web瀏覽器訪問(wèn)一次php文件,就會(huì)產(chǎn)生一個(gè)相應(yīng)時(shí)間戳的log文件,可以查看它記錄的信息。
我使用的log分析軟件是WinCacheGrind,因?yàn)槭莣indows版,所以需要使用wine啟動(dòng)。
接下來(lái),進(jìn)入WinCacheGrind就能看到每個(gè)函數(shù)執(zhí)行的時(shí)間了~
總結(jié):
希望本文介紹的在Ubuntu下使用Xdebug分析PHP程序的瓶頸的內(nèi)容能夠?qū)ψx者有所幫助,更多有關(guān)linux系統(tǒng)的知識(shí)還有待于讀者去探索和學(xué)習(xí)。
【編輯推薦】