xdebug使用说明
常用配置
xdebug.var_display_max_children
整数类型,默认值128
。用于控制通过xdebug_var_dump()
,var_dump()
方法时显示数组中子数组的个数或对象中属性的个数,设定为-1
关闭该限制。
xdebug.var_display_max_data
整数类型,默认值521
。用于控制xdebug_var_dump()
,var_dump()
方法时显示输出的字符串的长度,设定为-1
关闭该限制。
xdebug.var_display_max_depth
整数类型,默认值3
。用于控制通过xdebug_var_dump()
,var_dump()
方法时打印数组或对象时显示的层数,即深度。可设定的最大值为1023
,也可以将其设定为-1
以达到设定最大值的效果。
xdebug.collect_params
整数类型,默认值0
。如果一个方法的访问记录被跟踪时,打开该选项,会同时记录传递给该方法的所有参数信息。可设定一下值:
0 关闭
1 记录参数的类型和长度,如 string(6), array(8)
2 元素的类型和数量,带有完整信息的工具提示
3 完全变量内容(受XDebug .ValuDePosixMax子,XDebug .VARYDISPLAYX MAX数据)和XDebug .VARYDISPLAYMAX深度的限制。
4 完全变量内容和变量名。
xdebug.collect_vars
布而类型,默认值0
。用于收集当前作用域下哪些变量被使用。
常用方法
void xdebug_debug_zval( [string varname [, ...]] )
用于打印一个或多个变量结构的相关信息。包括变量类型,值以及变量引用次数。如果传递的是一个数组,则会递归数组中的所有元素。
void xdebug_dump_superglobals()
该方法用于打印出所有通过xdebug.dump.*
配置属性在php.ini
文件中指定的所有全局变量信息,如,在php.ini
文件中增加如下配置信息:
1 xdebug.dump.GET=*
2 xdebug.dump.SERVER=REMOTE_ADDR
在代码中通过调用xdebug_debug_zval()
方法打印出GET
下的所有变量信息以及SERVER['REMOTE_ADDR']
变量信息。
array xdebug_get_declared_vars()
返回一个数组,包含当前作用域下的所有变量名称,需要打开xdebug_collect.vars
配置。
array xdebug_get_function_stack()
一次打印出出调用xdebug_get_function_stack()
方法所在的方法的所有方法调用信息。
integer xdebug_get_stack_depth()
返回当前栈的深度,main()
深度为0
xdebug
跟踪
xdebug
可以将文件的运行流程及情况输出到日至文件中,通过访问这写文件,可以获取项目代码的运行流程以及相关一些信息,如内存使用率,内存峰值,执行时间等等。
输出到日至中的书写格式可以分为三种:易于阅读的格式,机器容易解析的格式以及HTML
格式,可以通过xdebug.trace_format
属性进行控制,其值有一下三种:
1 显示了一个人类可读的缩进跟踪文件,包括:时间索引、内存使用、内存增量(如果设置了xDebug
、SuffiMeMelta delta
),则级别、函数名、函数函数参数(如果设置了XDebug
。
2 编写具有两种不同记录的计算机可读格式。输入堆栈帧有不同的记录,并留下堆栈帧。下表列出了每种记录类型中的字段。字段是制表符分隔的。
3 在(简单)HTML
中写入一个格式化的跟踪。
同样,输出结果也会受到其他一些配置选项的影响,如xdebug.collect_params,xdebug.collect_return,xdebug.collect_assignments
为VIM
添加解析日至文件的语法高亮功能:
首先将源代码文件夹下的contrib/xt.vim
复制 ~/.vim/syntax
目录下
然后编辑 ~/.vim/filetype.vim
并加入一下代码:
1 augroup filetypedetect
2 au BufNewFile,BufRead *.xt setf xt
3 augroup END
此时在使用vim
打开生成的日志文件,即可看见对日志文件的格式化和高亮显示。
代码跟踪相关配置选项:
xdebug.auto_trace
boolean类型,默认值0。用于设定在脚本运行前是否自动跟踪方法的调用信息。
xdebug.collect_assignments
xdebug.collect_return
boolean类型,默认值0。用于设定是否返回调用方法的返回值。
xdebug.show_mem_delta
boolean类型,默认值0。如果启用该选项,并且输出格式为易于阅读式,则会在日志文件中显示调用两个方法之间的内存使用差异情况。
xdebug.trace_enable_trigger
boolean类型,默认值0。如果开启该选项,可以通过向POST或GET传递XDEBUG_TRACE参数来启用系统跟中功能,或者设定一个名为XDEBUG_TRACE的cookie信息,为了防止每次请求都会生成一个日志文件,需要将xdebug.auto_track设置为0。
xdebug.trace_format
xdebug.trace_options
boolean类型,默认值0。如果启用该选项,则之后的请求生成的日志信息会追加到日志文件中而不是替换当前日志文件中的内容。
xdebug.trace_output_dir
字符串类型,用于设定保存日志文件的路径信息
xdebug.trace_output_name
用于设定生成的日志文件的名字。
利用xdebug
检测项目性能
xdebug
提供了一个叫profiler
的功能,可以用来检测项目的性能,以便能够找出项目的瓶颈,使用该功能,首先需要了解一些配置参数:
xdebug.profiler_enable
boolean类型,默认值0。用于设定是否开启生成报告文件,如果设定为1,每次请求都会生成一个性能报告文件。
xdebug.profiler_enable_trigger
boolean类型,默认值0。如果开启该选项,则在每次请求中如果GET/POST或cookie中包含XDEBUG_PROFILE变量名,则才会生成性能报告文件(前提是必须关闭xdebug.profiler_enable选项,否则该选项不起作用)。
xdebug.profiler_output_dir
字符串类型。用于设定生成的报告文件的存放的路径。
xdebug.profiler_output_name
字符串类型。用于设定生成的报告文件的名字,如cachegrind.out.%t.%p