複製鏈接
請複製以下鏈接發送給好友

xdebug

鎖定
Xdebug是一個開放源代碼的PHP程序調試器(即一個Debug工具),可以用來跟蹤,調試和分析PHP程序的運行狀況。Xdebug2018年的最新版本是Xdebug 2.7.0beta1,release日期2018-09-20,添加了對PHP7.2的支持。
外文名
xdebug
類    別
開放源代碼PHP程序調試器
功    能
跟蹤、調試PHP程序的運行狀況

xdebug安裝與設置

xdebug安裝

下載xdebug
有兩個版本帶有Non-thread-safe和不帶有Non-thread-safe,主要是看php版本是否線程安全版本。
然後複製到php下的ext目錄裏,修改php.ini,增加如下信息:
[Xdebug]
zend_extension="x:\PHP\ext\php_xdebug-2.0.5-5.2.dll"
;以下是參數
xdebug.auto_trace=on
xdebug.collect_params=on
xdebug.collect_return=on
xdebug.trace_output_dir=”x:\Temp”
xdebug.profiler_enable=on
xdebug.profiler_output_dir=”x:\Temp”
;x為實際盤符

xdebug參數設置

xdebug.default_enable=on
;顯示默認的錯誤信息
xdebug.auto_trace=on
;自動打開“監測函數調用過程”的功模。該功能可以在指定的目錄中將函數調用的監測信息以文件的形式輸出。此配置項的默認值為off。
xdebug.collect_params=on
;打開收集“函數參數”的功能。將函數調用的參數值列入函數過程調用的監測信息中。此配置項的默認值為off。
xdebug.collect_return=on
;打開收集“函數返回值”的功能。將函數的返回值列入函數過程調用的監測信息中。此配置項的默認值為off。
xdebug.max_nesting_level=100
xdebug.profiler_enable=on
;打開效能監測器。
xdebug.remote_enable=on
;是否調試
xdebug.remote_host=localhost
xdebug.remote_port=9000
;調試端口
xdebug.remote_handler=dbgp
;選擇協議
xdebug.trace_output_dir="d:\Temp"
;設定函數調用監測信息的輸出文件的路徑。
xdebug.profiler_output_dir="d:\Temp"
;設定效能監測信息輸出文件的路徑。
設置完參數,重啓服務器,使用phpinfo() 函數查看是否有 xdebug 項目,安裝是否成功。
詳細的配置參數選項如下 [1] 
配置參數選項
參數值類型與默認值
參數選項描述
xdebug.auto_trace
boolean類型,默認值=0
是否在腳本運行之前自動調用相關追蹤函數。
xdebug.cli_color
integer類型,默認值=0
該參數自2.2版本開始引入。如果值=1,當處於CLI模式或連接虛擬控制枱時,Xdebug將高亮顯示var_dumps()和堆棧輸出,;在Windows中,這需要安裝ANSICON工具。如果值=2,不管是否處於CLI模式或連接虛擬控制枱,Xdebug都會高亮顯示var_dumps()或堆棧輸出;這種情況下,你可能會看到轉義後的代碼。
xdebug.collect_assignments
boolean類型,默認值=0
該參數自2.1版本開始引入。用於控制是否為函數跟蹤添加變量賦值功能。
xdebug.collect_includes
boolean類型,默認值=1
控制是否在跟蹤文件中寫入include()、include_once()、require()、require_once()等函數中用到的文件名。
xdebug.collect_params
integer類型,默認值=0
控制在調用函數時,是否收集傳遞給函數的參數信息。如果參數值過大,這可能會佔用大量的內存;不過,在Xdebug 2中不會出現該問題,因為Xdebug 2將相關數據寫入磁盤中,而不是佔用內存。
如果值=0,則不顯示任何信息。
如果值=1,只顯示類型和大小信息,例如:string(6)、array(8)。
如果值=2,將顯示類型和大小,以及全部信息的工具提示。
如果值=3,將顯示變量的全部內容。
如果值=4,將顯示變量的全部內容和變量名。
xdebug.collect_return
boolean類型,默認值=0
控制是否在追蹤文件中寫入函數調用返回值
xdebug.collect_vars
boolean類型,默認值=0
控制是否收集指定作用域中的變量信息。由於需要反向工程PHP操作碼數組,因此Xdebug的分析速度可能比較慢。
xdebug.coverage_enable
boolean類型,默認值=1
該參數自2.2版本開始引入。控制是否允許通過設置內部結構來啓用代碼覆蓋率功能。
xdebug.default_enable
boolean類型,默認值=1
當發生異常或錯誤時,是否默認顯示堆棧信息。
xdebug.dump.*
string類型,默認值=Empty
這裏的*可以是COOKIE, FILES, GET, POST, REQUEST, SERVER, SESSION中的任意一個。用於指定發生錯誤時是否顯示超全局變量數組中的索引變量信息。比如,你想要顯示請求的IP地址和請求方式,可以設置為
xdebug.dump.SERVER=REMOTE_ADD,REQUEST_METHOD
多個索引變量用英文逗號隔開,如果要輸出其中的所有變量,可以直接用*,例如:
xdebug.dump.GET=*
xdebug.dump_globals
boolean類型,默認值=1
控制是否顯示通過xdebug.dump.*定義的所有超全局變量的信息。
xdebug.dump_once
boolean類型,默認值=1
如果出現多個錯誤,控制超全局變量信息是在所有錯誤中顯示,還是隻在第一個錯誤中
xdebug.dump_undefined
boolean類型,默認值=1
控制是否顯示超全局變量中未定義的值
xdebug.extended_info
integer類型,默認值=1
是否強制進入PHP解析器的"extended_info"模式,這將允許Xdebug以遠程調試器對文件或行添加斷點。開啓此模式將拖慢腳本的允許速度,該參數只能在php.ini中設置。
xdebug.file_link_format
string類型,默認值=,
自2.2版本開始引入。用於指定堆棧信息中用到的文件名稱的鏈接樣式,這允許IDE通過設置鏈接協議,直接點擊堆棧信息中的文件名稱,即可快速打開指定的文件。例如:ZendStudio://%f@%l(%f表示文件路徑,%f表示行號)。
xdebug.force_display_errors
integer類型,默認值=0
自2.3版本開始引入。是否強制顯示錯誤信息。
xdebug.force_error_reporting
integer類型,默認值=0
自2.3版本開始引入。是否強制顯示所有錯誤級別的信息。

xdebug其它

由於效能監測文件:cachegrind.out.××××××××文件的內容不易被人類所理解,所以需要一個工具來讀取它。windows下就有一款這樣的軟件:wincachegrind。
1、下載安裝wincachegrind
2、安裝運行後,點擊Tools->options,設定working folder(php.ini裏xdebug.profiler_output_dir的值)
這樣就可以比較直觀的查看效能監測文件的信息了。
參考資料