出處:http://www.leapsoul.cn/?p=935
說到PHP代碼調試,對於有經驗的PHPer,通過echo、print_r、var_dump函數,或PHP開發工具zend studio、editplus可解決大部分問題,但是對於PHP入門學習的童鞋來說有一定的難度,而且僅僅通過上述這些PHP調試手段,也很難準確發現PHP性能方面的問題,Xdebug是一個非常有用的PHP調試工具。
Xdebug作爲PHP調試工具,提供了豐富的調試函數,也可將Xdebug安裝配置爲zend studio、editplus調試PHP的第三方插件,通過開啓自動跟蹤(auto_trace)和分析器功能,可以直觀的看到PHP源代碼的性能數據,以便優化PHP代碼。今天和大家分享PHP調試工具Xdebug安裝以及配置方面的基礎知識。
Xdebug在PHP中的安裝配置涉及php.ini配置文件的修改。
Xdebug安裝教程
下載Xdebug
首先我們需要下載Xdebug,務必根據安裝的PHP版本,選擇合適的Xdebug版本,由於我是在Windows環境下安裝PHP的,所以選擇下載Windows版本的Xdebug2.2.2(5.4VC6 (32 bit)),下載下來的Xdebug文件爲pphp_xdebug-2.2.2-5.4-vc9-nts.dll,這是由於Xdebug是作爲PHP模塊的形式被安裝配置與使用的。
Xdebug安裝提示:如果你不清楚安裝的PHP版本,你可以通過phpinfo()函數參看,同時Xdebug也提供了phpinfo輸出信息分析工具來幫助你分析如何安裝Xdebug,只要將phpinfo輸出信息複製提交即可,地址:Xdebug phpinfo信息分析地址
安裝Xdebug
將下載的php_xdebug-2.2.2-5.4-vc9-nts.dll複製到PHP安裝目錄下的ext目錄,此處爲C:\php\ext,ext目錄專門用來存放PHP擴展庫DLL文件。
配置php.ini
安裝Xdebug的最後一步就是配置php.ini文件,打開C:\php目錄下的php.ini配置文件,在末尾添加
zend_extension="c:/php/ext/php_xdebug-2.1.0-5.3-vc6.dll"
最後重啓Apache服務器,通過phpinfo()函數,可以看到
Xdebug配置提示:PHP5.3之前版本配置Xdebug時使用zend_extension_ts,對於PHP5.3以上版本,使用zend_extension。
XDEBUG NOT LOADED AS ZEND EXTENSION信息出現的原因
出現XDEBUG NOT LOADED AS ZEND EXTENSION的原因是在安裝Xdebug時由於我們將Xdebug的DLL文件複製到了php\ext目錄下,容易以PHP擴展庫的形式加載Xdebug,在php.ini文件中添加了
這是錯誤的Xdebug安裝方式,必須以zend方式加載。
至此PHP Xdebug的基礎安裝教程就結束了,下面我們需要對Xdebug作一些基礎配置。
Xdebug配置教程
在安裝完Xdebug後,我們還需要對Xdebug做基礎配置,默認Xdebug的PHP函數自動跟蹤(auto_trace)功能、分析器功能並沒有開啓,作爲調試PHP代碼的需要,有些Xdebug配置選項最好開啓。
在此之前我們需要創建Xdebug自動跟蹤以及分析器輸出文件的存放目錄,務必確保目錄是可讀寫的,此處我在D:\PHPWeb\下創建了xdebug\trace以及xdebug\profiler目錄。
最後在php.ini配置文件中完成Xdebug的配置工作,找到
zend_extension="c:/php/ext/php_xdebug-2.1.0-5.3-vc6.dll"
在此之後添加Xdebug配置信息
xdebug.collect_params=1
xdebug.collect_return=1
xdebug.trace_output_dir="D:/PHPWeb/xdebug/trace"
xdebug.profiler_enable=1
xdebug.profiler_output_dir="D:/PHPWeb/xdebug/profiler"
最後保存php.ini,並重啓Aapche服務器即可。
Xdebug部分配置選項說明
xdebug.auto_trace = 1
是否允許Xdebug跟蹤函數調用,跟蹤信息以文件形式存儲,默認值爲0
collect_params = 1
是否允許Xdebug跟蹤函數參數,默認值爲0
xdebug.collect_return = 1
是否允許Xdebug跟蹤函數返回值,默認值爲0
xdebug.profiler_enable = 1
打開xdebug的性能分析器,以文件形式存儲,這項配置是不能以ini_set()函數配置的,默認值爲0
xdebug.profiler_output_dir
性能分析文件的存放位置,默認值爲/tmp
xdebug.profiler_output_name
性能分析文件的命名規則,默認值爲cachegrind.out.%p
xdebug.trace_output_dir
函數調用跟蹤信息輸出文件目錄,默認值爲/tmp
xdebug.trace_output_name
函數調用跟蹤信息輸出文件命名規則,默認爲trace.%c
特別說明:Xdebug的trace和profiler的輸出文件名規則是可以更改的,比如將文件名命名爲具體跟蹤的PHP執行文件名、進程ID、隨機數等,非常方便,更多的Xdebug配置選項說明,請參考官網的Xdebug配置選項說明。
至此PHP調試工具Xdebug教程之Xdebug的安裝和配置就介紹完了,今後還將陸續介紹Xdebug如何在zend studio以及editplus中配置使用。
摘自:http://www.leapsoul.cn/?p=935
個人配置備份:
zend_extension="D:\php\xampp\php\ext\php_xdebug.dll"
xdebug.remote_enable=true
xdebug.remote_host=127.0.0.1
xdebug.remote_port=9000
xdebug.remote_handler=dbgp