목차
Xdebug文档(四)函数跟踪,xdebug文档函数跟踪
输出格式
The Script
The Results
VIM 语法文件
백엔드 개발 PHP 튜토리얼 Xdebug文档(四)函数跟踪,xdebug文档函数跟踪_PHP教程

Xdebug文档(四)函数跟踪,xdebug文档函数跟踪_PHP教程

Jul 12, 2016 am 08:50 AM
xdebug

Xdebug文档(四)函数跟踪,xdebug文档函数跟踪

Xdebug能让你把所有函数调用,包括参数和返回值以不同的格式记录到文件中。

这些号称“函数跟踪”功能能帮助你面对一个新应用程序,亦或者在程序运行时你想弄清楚它在做什么。函数跟踪功能可以选择性地显示函数或方法传递的变量值,也可以是返回值。跟踪这两个元素默认情况下不开启的。

输出格式

共有三种输出格式。一种是人类可读性跟踪信息,另一个是更适合计算机程序解析的,最后一种使用HTML格式化跟踪信息的。你可以使用xdebug_trace_format设置切换这两种不周的格式。还有一些设置是控制哪些信息写入跟踪文件的。例如设置包含变量的(xdebug.collect_params)和包含返回值的(xdebug.collect_return)。以下例子展示人类可读性的函数跟踪信息的不同设置效果:

The Script

<span>php
</span><span>$str</span> = "Xdebug"<span>;
</span><span>function</span> ret_ord( <span>$c</span><span> )
{
    </span><span>return</span> <span>ord</span>( <span>$c</span><span> );
}

</span><span>foreach</span> ( <span>str_split</span>( <span>$str</span> ) <span>as</span> <span>$char</span><span> )
{
    </span><span>echo</span> <span>$char</span>, ": ", ret_ord( <span>$char</span> ), "\n"<span>;
}
</span>?>
로그인 후 복사


 

The Results

以下由xdebug.collect_params设置不同值时的结果。当不在web环境下,2值不包含鼠标提示。

默认值:

TRACE START [2007-05-06 14:37:06]

    0.0003     114112   -> {main}() ../trace.php:0

    0.0004     114272     -> str_split() ../trace.php:8

    0.0153     117424     -> ret_ord() ../trace.php:10

    0.0165     117584       -> ord() ../trace.php:5

    0.0166     117584     -> ret_ord() ../trace.php:10

    0.0167     117584       -> ord() ../trace.php:5

    0.0168     117584     -> ret_ord() ../trace.php:10

    0.0168     117584       -> ord() ../trace.php:5

    0.0170     117584     -> ret_ord() ../trace.php:10

    0.0170     117584       -> ord() ../trace.php:5

    0.0172     117584     -> ret_ord() ../trace.php:10

    0.0172     117584       -> ord() ../trace.php:5

    0.0173     117584     -> ret_ord() ../trace.php:10

    0.0174     117584       -> ord() ../trace.php:5

    0.0177      41152

TRACE END   [2007-05-06 14:37:07]

 

Collect_params=1:

TRACE START [2007-05-06 14:37:11]
로그인 후 복사
    0.0003     114112   -> {main}() ../trace.php:0
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
    0.0004     114272     -> str_split(string(6)) ../trace.php:8
로그인 후 복사
    0.0007     117424     -> ret_ord(string(1)) ../trace.php:10
로그인 후 복사
    0.0007     117584       -> ord(string(1)) ../trace.php:5
로그인 후 복사
    0.0009     117584     -> ret_ord(string(1)) ../trace.php:10
로그인 후 복사
    0.0009     117584       -> ord(string(1)) ../trace.php:5
로그인 후 복사
    0.0010     117584     -> ret_ord(string(1)) ../trace.php:10
로그인 후 복사
    0.0011     117584       -> ord(string(1)) ../trace.php:5
로그인 후 복사
    0.0012     117584     -> ret_ord(string(1)) ../trace.php:10
로그인 후 복사
    0.0013     117584       -> ord(string(1)) ../trace.php:5
로그인 후 복사
    0.0014     117584     -> ret_ord(string(1)) ../trace.php:10
로그인 후 복사
    0.0014     117584       -> ord(string(1)) ../trace.php:5
로그인 후 복사
    0.0016     117584     -> ret_ord(string(1)) ../trace.php:10
로그인 후 복사
    0.0016     117584       -> ord(string(1)) ../trace.php:5
로그인 후 복사
    0.0019      41152
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
TRACE END   [2007-05-06 14:37:11]
로그인 후 복사

Collect_params=3:

TRACE START [2007-05-06 14:37:13]
로그인 후 복사
    0.0003     114112   -> {main}() ../trace.php:0
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
    0.0004     114272     -> str_split('Xdebug') ../trace.php:8
로그인 후 복사
로그인 후 복사
로그인 후 복사
    0.0007     117424     -> ret_ord('X') ../trace.php:10
로그인 후 복사
    0.0007     117584       -> ord('X') ../trace.php:5
로그인 후 복사
로그인 후 복사
로그인 후 복사
    0.0009     117584     -> ret_ord('d') ../trace.php:10
로그인 후 복사
    0.0009     117584       -> ord('d') ../trace.php:5
로그인 후 복사
로그인 후 복사
로그인 후 복사
    0.0010     117584     -> ret_ord('e') ../trace.php:10
로그인 후 복사
    0.0011     117584       -> ord('e') ../trace.php:5
로그인 후 복사
로그인 후 복사
로그인 후 복사
    0.0012     117584     -> ret_ord('b') ../trace.php:10
로그인 후 복사
    0.0013     117584       -> ord('b') ../trace.php:5
로그인 후 복사
로그인 후 복사
로그인 후 복사
    0.0014     117584     -> ret_ord('u') ../trace.php:10
로그인 후 복사
    0.0014     117584       -> ord('u') ../trace.php:5
로그인 후 복사
로그인 후 복사
    0.0016     117584     -> ret_ord('g') ../trace.php:10
로그인 후 복사
    0.0016     117584       -> ord('g') ../trace.php:5
로그인 후 복사
로그인 후 복사
    0.0019      41152
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
TRACE END   [2007-05-06 14:37:13]
로그인 후 복사

Collect_params=4:

TRACE START [2007-05-06 14:37:16]
로그인 후 복사
    0.0003     114112   -> {main}() ../trace.php:0
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
    0.0004     114272     -> str_split('Xdebug') ../trace.php:8
로그인 후 복사
로그인 후 복사
로그인 후 복사
    0.0007     117424     -> ret_ord($c = 'X') ../trace.php:10
로그인 후 복사
로그인 후 복사
    0.0007     117584       -> ord('X') ../trace.php:5
로그인 후 복사
로그인 후 복사
로그인 후 복사
    0.0009     117584     -> ret_ord($c = 'd') ../trace.php:10
로그인 후 복사
로그인 후 복사
    0.0009     117584       -> ord('d') ../trace.php:5
로그인 후 복사
로그인 후 복사
로그인 후 복사
    0.0010     117584     -> ret_ord($c = 'e') ../trace.php:10
로그인 후 복사
    0.0011     117584       -> ord('e') ../trace.php:5
로그인 후 복사
로그인 후 복사
로그인 후 복사
    0.0012     117584     -> ret_ord($c = 'b') ../trace.php:10
로그인 후 복사
    0.0013     117584       -> ord('b') ../trace.php:5
로그인 후 복사
로그인 후 복사
로그인 후 복사
    0.0014     117584     -> ret_ord($c = 'u') ../trace.php:10
로그인 후 복사
    0.0014     117584       -> ord('u') ../trace.php:5
로그인 후 복사
로그인 후 복사
    0.0016     117584     -> ret_ord($c = 'g') ../trace.php:10
로그인 후 복사
    0.0016     117584       -> ord('g') ../trace.php:5
로그인 후 복사
로그인 후 복사
    0.0019      41152
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
TRACE END   [2007-05-06 14:37:16]
로그인 후 복사

除了xdebug.collet_params设置还有另一些设置影响跟踪文件的输出效果。“show_mem_delta=1”可以显示内存使用量在两个不同列中。

TRACE START [2007-05-06 14:37:26]
로그인 후 복사
    0.0003     114112  +114112   -> {main}() ../trace.php:0
로그인 후 복사
    0.0004     114272     +160     -> str_split('Xdebug') ../trace.php:8
로그인 후 복사
    0.0007     117424    +3152     -> ret_ord($c = 'X') ../trace.php:10
로그인 후 복사
    0.0007     117584     +160       -> ord('X') ../trace.php:5
로그인 후 복사
    0.0009     117584       +0     -> ret_ord($c = 'd') ../trace.php:10
로그인 후 복사
    0.0009     117584       +0       -> ord('d') ../trace.php:5
로그인 후 복사
    0.0011     117584       +0     -> ret_ord($c = 'e') ../trace.php:10
로그인 후 복사
    0.0011     117584       +0       -> ord('e') ../trace.php:5
로그인 후 복사
    0.0013     117584       +0     -> ret_ord($c = 'b') ../trace.php:10
로그인 후 복사
    0.0013     117584       +0       -> ord('b') ../trace.php:5
로그인 후 복사
    0.0014     117584       +0     -> ret_ord($c = 'u') ../trace.php:10
로그인 후 복사
    0.0015     117584       +0       -> ord('u') ../trace.php:5
로그인 후 복사
    0.0016     117584       +0     -> ret_ord($c = 'g') ../trace.php:10
로그인 후 복사
    0.0017     117584       +0       -> ord('g') ../trace.php:5
로그인 후 복사
    0.0019      41152
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
TRACE END   [2007-05-06 14:37:26]
로그인 후 복사

“collect_return=1”显示被调用函数的返回值:

TRACE START [2007-05-06 14:37:35]
로그인 후 복사
    0.0003     114112   -> {main}() ../trace.php:0
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
    0.0004     114272     -> str_split('Xdebug') ../trace.php:8
로그인 후 복사
로그인 후 복사
로그인 후 복사
                          >=> array (0 => 'X', 1 => 'd', 2 => 'e', 3 => 'b', 4 => 'u', 5 => 'g')
로그인 후 복사
    0.0007     117424     -> ret_ord($c = 'X') ../trace.php:10
로그인 후 복사
로그인 후 복사
    0.0007     117584       -> ord('X') ../trace.php:5
로그인 후 복사
로그인 후 복사
로그인 후 복사
                            >=> 88
로그인 후 복사
                          >=> 88
로그인 후 복사
    0.0009     117584     -> ret_ord($c = 'd') ../trace.php:10
로그인 후 복사
로그인 후 복사
    0.0009     117584       -> ord('d') ../trace.php:5
로그인 후 복사
로그인 후 복사
로그인 후 복사
                            >=> 100
로그인 후 복사
                          >=> 100
로그인 후 복사
    0.0011     117584     -> ret_ord($c = 'e') ../trace.php:10
로그인 후 복사
    0.0011     117584       -> ord('e') ../trace.php:5
로그인 후 복사
로그인 후 복사
로그인 후 복사
                            >=> 101
로그인 후 복사
                          >=> 101
로그인 후 복사
    0.0013     117584     -> ret_ord($c = 'b') ../trace.php:10
로그인 후 복사
    0.0013     117584       -> ord('b') ../trace.php:5
로그인 후 복사
로그인 후 복사
로그인 후 복사
                            >=> 98
로그인 후 복사
                          >=> 98
로그인 후 복사
    0.0015     117584     -> ret_ord($c = 'u') ../trace.php:10
로그인 후 복사
    0.0016     117584       -> ord('u') ../trace.php:5
로그인 후 복사
                            >=> 117
로그인 후 복사
                          >=> 117
로그인 후 복사
    0.0017     117584     -> ret_ord($c = 'g') ../trace.php:10
로그인 후 복사
    0.0018     117584       -> ord('g') ../trace.php:5
로그인 후 복사
                            >=> 103
로그인 후 복사
                          >=> 103
로그인 후 복사
                        >=> 1
로그인 후 복사
    0.0021      41152
로그인 후 복사
TRACE END   [2007-05-06 14:37:35]
로그인 후 복사

 

“collect_assignments=1”显示变量赋予,详见xdebug.collect_assignments设置。

“xdebug.trace_format”设置改变输出格式让解析更容易但反而让人更难理解。这对于用第三方工具解析跟踪文件最有用处。

Version: 2.0.0RC4-dev
로그인 후 복사
TRACE START [2007-05-06 18:29:01]
로그인 후 복사
1       0       0       0.010870       114112  {main}  1       ../trace.php   0
로그인 후 복사
2       1       0       0.032009       114272  str_split      0       ../trace.php   8
로그인 후 복사
2       1       1       0.032073       116632
로그인 후 복사
2       2       0       0.033505       117424  ret_ord 1       ../trace.php   10
로그인 후 복사
3       3       0       0.033531       117584  ord     0       ../trace.php   5
로그인 후 복사
3       3       1       0.033551       117584
로그인 후 복사
2       2       1       0.033567       117584
로그인 후 복사
2       4       0       0.033718       117584  ret_ord 1       ../trace.php   10
로그인 후 복사
3       5       0       0.033740       117584  ord     0       ../trace.php   5
로그인 후 복사
3       5       1       0.033758       117584
로그인 후 복사
2       4       1       0.033770       117584
로그인 후 복사
2       6       0       0.033914       117584  ret_ord 1       ../trace.php   10
로그인 후 복사
3       7       0       0.033936       117584  ord     0       ../trace.php   5
로그인 후 복사
3       7       1       0.033953       117584
로그인 후 복사
2       6       1       0.033965       117584
로그인 후 복사
2       8       0       0.034108       117584  ret_ord 1       ../trace.php   10
로그인 후 복사
3       9       0       0.034130       117584  ord     0       ../trace.php   5
로그인 후 복사
3       9       1       0.034147       117584
로그인 후 복사
2       8       1       0.034160       117584
로그인 후 복사
2       10      0       0.034302       117584  ret_ord 1       ../trace.php   10
로그인 후 복사
3       11      0       0.034325       117584  ord     0       ../trace.php   5
로그인 후 복사
3       11      1       0.034342       117584
로그인 후 복사
2       10      1       0.034354       117584
로그인 후 복사
2       12      0       0.034497       117584  ret_ord 1       ../trace.php   10
로그인 후 복사
3       13      0       0.034519       117584  ord     0       ../trace.php   5
로그인 후 복사
3       13      1       0.034536       117584
로그인 후 복사
2       12      1       0.034549       117584
로그인 후 복사
1       0       1       0.034636       117584
로그인 후 복사
TRACE END   [2007-05-06 18:29:01]
로그인 후 복사

 

VIM 语法文件

Xdebug 携带一个VIM语法文件能对跟踪文件的语法提亮,该语法文件名:xt.vim。 为了使VIM识别新格式,你需这么做:

augroup filetypedetect
로그인 후 복사
au BufNewFile,BufRead *.xt  setf xt
로그인 후 복사
augroup END
로그인 후 복사

做完这些后,打开的跟踪文件就会类似这样:

<strong>TRACE START</strong> <strong>[2007-05-15 20:06:02]</strong>
로그인 후 복사
    0.0003     115208   <strong>-></strong> <strong>{main}()</strong> ../trace.php<strong>:0</strong>
로그인 후 복사
    0.0004     115368     <strong>-></strong> <strong>str_split() </strong>../trace.php<strong>:8</strong>
로그인 후 복사
    0.0006     118520     <strong>-></strong> <strong>ret_ord() </strong>../trace.php<strong>:10</strong>
로그인 후 복사
    0.0007     118680       <strong>-></strong> <strong>ord() </strong>../trace.php<strong>:5</strong>
로그인 후 복사
    0.0008     118680     <strong>-></strong> <strong>ret_ord() </strong>../trace.php<strong>:10</strong>
로그인 후 복사
    0.0009     118680       <strong>-></strong> <strong>ord() </strong>../trace.php<strong>:5</strong>
로그인 후 복사
    0.0010     118680     <strong>-></strong> <strong>ret_ord() </strong>../trace.php<strong>:10</strong>
로그인 후 복사
    0.0010     118680       <strong>-></strong> <strong>ord() </strong>../trace.php<strong>:5</strong>
로그인 후 복사
    0.0012     118680     <strong>-></strong> <strong>ret_ord() </strong>../trace.php<strong>:10</strong>
로그인 후 복사
    0.0012     118680       <strong>-></strong> <strong>ord() </strong>../trace.php<strong>:5</strong>
로그인 후 복사
    0.0014     118680     <strong>-></strong> <strong>ret_ord() </strong>../trace.php<strong>:10</strong>
로그인 후 복사
    0.0014     118680       <strong>-></strong> <strong>ord() </strong>../trace.php<strong>:5</strong>
로그인 후 복사
    0.0016     118680     <strong>-></strong> <strong>ret_ord() </strong>../trace.php<strong>:10</strong>
로그인 후 복사
    0.0016     118680       <strong>-></strong> <strong>ord() </strong>../trace.php<strong>:5</strong>
로그인 후 복사
    0.0019      54880
로그인 후 복사
<strong>TRACE END</strong>   <strong>[2007-05-15 20:06:02]<br></strong>
로그인 후 복사

相关设置:

xdebug.auto_trace

类型: boolean, 默认值: 0

打开此设置时,脚本在运行前函数调用追踪将开启。这将可能追踪auto_prepend_file设置的代码文件。

xdebug.collect_assignments

类型: boolean, 默认值: 0, 始于 Xdebug > 2.1

用于控制xdebug是否添加变量赋予到函数追踪当中。

xdebug.collect_includes

类型: boolean, 默认值: 1

用于控制xdebug是否将include(), include_once(), require() 或 require_once() 引用的文件名写入到跟踪文件中。

xdebug.collect_params

类型: integer, 默认值: 0

默认为0时,该设置控制xdebug不管是函数追踪还是堆栈跟踪都会收集调用函数的参数。

默认0值是考虑到大规模脚本会占用大量内存,所以不会为了大脚本来运行它。你可以安全地打开此设置,但你会预料到会一些脚本上的问题像大量函数调用兼庞大的数据结构作为参数传递。Xdebug2不会有增加内存使用的问题,因为它不会存储到内存,而是只存入磁盘中。这只需要你有足够的磁盘使用量即可。

该设置有4种设置值。每种都会呈现不同的信息。以下表格展示各种设置值信息:

Value

Argument   Information   Shown

0

无.

1

展示变量元素的值类型和值。

2

展示变量元素的值类型和值,并附带滑鼠提示显示完整信息。(CLI模式下不存在滑鼠提示)

3

完整变量内容(内容受限于以下设置: xdebug.var_display_max_children,xdebug.var_display_max_data and xdebug.var_display_max_depth.)

4

完整变量内容和名称。

5

PHP   序列化变量内容,不含名称。(2.3版本新特性)

 

xdebug.collect_return

类型: boolean, 默认值: 0

控制是否将函数调用的返回值写入到跟踪文件里。

要达到计算机化跟踪文件(xdebug.trace_format=1) 必须要用到Xdebug 2.3 以上版本。

 

xdebug.show_mem_delta

类型: integer, 默认值: 0

当此设置不为0值,可人为读取的跟踪文件将各函数调用占用内存量的不同。如果xdebug设置为产生计算机可读的跟踪文件,则他们会一直显示这样的信息。

 

xdebug.trace_enable_trigger

类型: boolean, 默认值: 0, 始于 Xdebug > 2.2

设置为1时,你能使用XDEBUG_TRACE GET/POST 参数或设置一名为XDEBUG_TRACE的cookie值触发跟踪文件的产生。跟踪数据文件将写入到预定义文件夹内。为了防止xdebug在每次请求时产生跟踪文件,你需要将xdebug.auto_trace设为0。访问触发器自身可通过设置 xdebug.trace_enable_trigger_value。

 

xdebug.trace_enable_trigger_value

类型: string, 默认值: "", 始于 Xdebug > 2.3

该设置用于限制谁能利用XDEBUG_TRACE功能描述到xdebug.trace_enable_trigger。当变更了默认空值后,cookie,GET或POST值需要为跟踪文件的产生匹配设置内的共享隐藏设置。

 

xdebug.trace_format

类型: integer, 默认值: 0

跟踪文件的格式。

描述

0

显示人类可读性排版式文件:时间点,内存量,内存增量(如果xdebug.show_mem_delta 开启), 层级, 函数名, 函数参数 (如果 xdebug.collect_params 开启),文件名和行号。

1

用两种不同记录编写记算机可读格式文件。其记录不同在于一个插入堆栈边框,一个移除堆栈边框。以下表格列出记录中每个栏位区别。

2

使用HTML写成跟踪文件。

计算机化格式的栏位:

Record type

1

2

3

4

5

6

7

8

9

10

11

12 - ...

Entry

level

function #

always '0'

time index

memory usage

function name

user-defined (1)   or internal function (0)

name of   the include/require file

filename

line number

no. of parameters

parameters   (as many as specified in field 11) - tab separated

Exit

level

function #

always '1'

time index

memory usage

empty

Return

level

function #

always 'R'

empty

return value

empty

 

xdebug.trace_options

类型: integer, 默认值: 0

设为1时跟踪文件会后续添加内容,而不是在后续请求中直接覆盖。

 

xdebug.trace_output_dir

类型: string, 默认值: /tmp

跟踪文件写入路径,确保用户在运行PHP时有对该目录的写入权限。

 

xdebug.trace_output_name

类型: string, 默认值: trace.%c

该设置决定了跟踪信息写入的文件名。该设置使用了格式化标识符,类似于sprintf() 和 strftime()。 以几种格式标识符可以用于格式化文件名。后缀名 '.xt' 会自动地添加到文件名后。

格式化标识符列表:

标识符

意义

格式范例

文件范例

%c

当前工作路径的crc32效验值

trace.%c

trace.1258863198.xt

%p

进程标识符

trace.%p

trace.5174.xt

%r

随机数

trace.%r

trace.072db0.xt

%s

脚本名 2

cachegrind.out.%s

cachegrind.out._home_httpd_html_test_xdebug_test_php

%t

时间截 (秒)

trace.%t

trace.1179434742.xt

%u

时间截 (微秒)

trace.%u

trace.1179434749_642382.xt

%H

$_SERVER['HTTP_HOST']

trace.%H

trace.kossu.xt

%R

$_SERVER['REQUEST_URI']

trace.%R

trace._test_xdebug_test_php_var=1_var2=2.xt

%U

$_SERVER['UNIQUE_ID'] 3

trace.%U

trace.TRX4n38AAAEAAB9gBFkAAAAB.xt

%S

session_id   (来源$_COOKIE,如果有设置)

trace.%S

trace.c70c1ec2375af58f74b390bbdd2a679d.xt

%%

literal %

trace.%%

trace.%%.xt

2 对于跟踪文件名这是不可用的。

3 版本2.2新特性。该特性由Apache mod_unique_id module 设置。

 

xdebug.var_display_max_children

类型: integer, 默认值: 128

在使用 xdebug_var_dump(),xdebug.show_local_vars 或 追踪函数时,该设置控制数组元素和对象属性的数量显示。

若不受限制,可以设为-1值。

该设置不受Remot_Debuggin远程调试的任何影响。

 

xdebug.var_display_max_data

类型: integer, 默认值: 512

在使用 xdebug_var_dump(),xdebug.show_local_vars 或 追踪函数时,该设置控制字符串长度显示最大值。

若不受限制,可以设为-1值。

该设置不受Remot_Debugging远程调试的任何影响。

 

xdebug.var_display_max_depth

类型: integer, 默认值: 3

在使用 xdebug_var_dump(),xdebug.show_local_vars 或 追踪函数时,该设置控制数组元素和对象属性的显示层级。

最大值为1023,你可以设为-1表示其最大值。

该设置不受Remot_Debugging远程调试的任何影响。

 

相关函数:

string xdebug_get_tracefile_name()

返回当前跟踪输出的脚本文件名。当xdebug.auto_trace打开时这个函数就能使用了。

 

void xdebug_start_trace( string trace_file [, integer options] )

启动一新的函数跟踪

位于某个点开始函数跟踪并入到参数trace_file指定的文件中。如果没有指定文件名,则跟踪文件存入 xdebug.trace_output_dir设定指定目录中。一旦在第一参数中指定了文件名,则该名称相对于当前工作目录。不过当前工作目录可能与你期望的不一样,所以在指定文件名时最好指定绝对目录。PHP函数 getcwd() 能指出当前工作目录。

跟踪文件名一般是"{trace_file}.xt"。如果 xdebug.auto_trace 开启,那么文件名"{filename}.xt"的"{filename}"部分由设置 xdebug.trace_output_name 决定。参数options是比特值,有三种选项:

XDEBUG_TRACE_APPEND (1)

使跟踪文件以追加模式打开而不是覆盖模式。

XDEBUG_TRACE_COMPUTERIZED (2)

创建一个跟踪文件而其格式由"xdebug.trace_format"描述。

XDEBUG_TRACE_HTML (4)

以html表格创建跟踪文件。

XDEBUG_TRACE_NAKED_FILENAME (8)

一般来说,Xdebug会添加".xt"到你指定的第一个参数的文件名结尾。使用XDEBUG_TRACE_NAKED_FILENAME选项, ".xt" 则不会再添加 (Xdebug 2.3新特性).

不像Xdebug 1,Xdebug 2不会在函数调用时占用内存。,但它会写入磁盘而缓解内存使用的压力。 xdebug.collect_includes, xdebug.collect_params 和xdebug.collect_return 等设置会影响跟踪文件记录什么样的信息,而xdebug.trace_format 则影响文件信息的格式。

 

void xdebug_stop_trace()

停止跟踪函数调用并关闭跟踪文件。

 

www.bkjia.comtruehttp://www.bkjia.com/PHPjc/1133567.htmlTechArticleXdebug文档(四)函数跟踪,xdebug文档函数跟踪 Xdebug能让你把所有函数调用,包括参数和返回值以不同的格式记录到文件中。 这些号称函数...
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
4 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
4 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
4 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25 : Myrise에서 모든 것을 잠금 해제하는 방법
1 몇 달 전 By 尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

프로덕션 서버에서 XDebug를 활성화하면 PHP 속도가 느려지나요? 프로덕션 서버에서 XDebug를 활성화하면 PHP 속도가 느려지나요? Sep 22, 2023 pm 10:41 PM

예, XDebug와 같은 디버거는 PHP 서버 성능을 저하시킬 수 있습니다. 이것이 디버거가 서버 환경에 배치되지 않는 이유입니다. 불필요한 오버헤드를 피하기 위해 다양한 환경에 배포됩니다. 이미 프로덕션 중인 애플리케이션에는 디버그 메시지를 표시할 수 없습니다. 디버깅 동작이 서버에 추가되면 디버깅 엔진이 PHP 프로세스에 연결됩니다. 중단점에서 중지하라는 메시지 수신을 시작하지만 이는 다른 프로세스에 성능 저하를 주어 PHP 파서를 중지하므로 필수 동작은 아닙니다. 반면에 디버거를 설치하면 프로덕션 환경에서 사용하기 위한 것이 아니기 때문에 서버에서 포트를 여는 경향이 있습니다. 서버에서 포트를 여는 것은 해커가 엿볼 수 있도록 문을 여는 것만큼 나쁩니다.

PHP8.0의 디버깅 라이브러리: Xdebug PHP8.0의 디버깅 라이브러리: Xdebug May 14, 2023 am 08:09 AM

디버깅은 PHP 개발에서 피할 수 없는 부분입니다. 개발자가 자신의 코드를 보다 쉽게 ​​디버그할 수 있도록 돕기 위해 PHP8.0은 디버깅 라이브러리에 Xdebug라는 매우 유용한 도구를 도입했습니다. 이 기사에서는 Xdebug의 주요 기능 중 일부와 이를 사용하여 PHP 디버깅 프로세스를 단순화하는 방법을 소개합니다. Xdebug는 PHP 애플리케이션의 오류를 캡처하고 자세한 오류 스택 추적 정보와 사용 중인 변수를 제공할 수 있는 오픈 소스 디버깅 도구입니다. 개발자가 코드를 감지하고 문제를 해결하는 데 도움이 됩니다.

ThinkPHP6에서 Xdebug 디버깅 기술 사용 ThinkPHP6에서 Xdebug 디버깅 기술 사용 Jun 20, 2023 pm 09:14 PM

ThinkPHP6은 다양한 기술을 사용하여 개발을 보다 편리하게 만드는 인기 있는 PHP 프레임워크입니다. 그러한 기술 중 하나가 Xdebug와 같은 디버깅 도구입니다. 이 기사에서는 ThinkPHP6에서 디버깅을 위해 Xdebug를 사용하는 방법을 살펴보겠습니다. Xdebug 설치 및 구성 Xdebug를 사용하기 전에 먼저 Xdebug를 설치하고 활성화해야 합니다. php.ini 파일에서 다음 구성을 추가할 수 있습니다: [xdebug]zend_extension=x

PHP의 개발 도구 PHP의 개발 도구 May 23, 2023 am 08:18 AM

PHP는 웹 개발에 널리 사용되는 프로그래밍 언어입니다. PHP 개발 도구의 경우 적합한 도구를 선택하면 개발자의 작업이 더욱 효율적이고 편리해질 수 있습니다. 이 기사에서는 통합 개발 환경(IDE), 텍스트 편집기 및 디버깅 도구를 포함한 몇 가지 일반적인 PHP 개발 도구에 대해 설명합니다. 1. 통합 개발 환경(IDE) PhpStorm PhpStorm은 JetBrains에서 개발한 강력한 PHP 개발 환경입니다. PH를 지원할 뿐만 아니라

효율적인 디버깅 및 성능 최적화를 위해 PHP 확장 XDebug를 사용하는 방법 효율적인 디버깅 및 성능 최적화를 위해 PHP 확장 XDebug를 사용하는 방법 Jul 29, 2023 pm 08:57 PM

효율적인 디버깅 및 성능 최적화를 위해 PHP 확장 XDebug를 사용하는 방법 PHP 애플리케이션을 개발하고 디버깅할 때 잘못된 호출, 비효율적인 코드, 성능 병목 현상 등 다양한 문제에 직면하는 경우가 많습니다. XDebug는 이러한 문제를 신속하게 찾아 디버깅하고 최적화하는 데 도움이 되는 강력한 PHP 확장입니다. 이 기사에서는 효율적인 디버깅 및 성능 최적화를 위해 XDebug를 사용하는 방법을 소개하고 몇 가지 코드 예제를 제공합니다. XDebug 설치 및 구성 먼저 XDebug를 설치해야 합니다.

PHP 개발: Xdebug 및 PHPUnit을 사용한 중단점 디버깅 및 단위 테스트 PHP 개발: Xdebug 및 PHPUnit을 사용한 중단점 디버깅 및 단위 테스트 Jun 15, 2023 pm 07:55 PM

PHP 개발자는 개발 프로세스 중에 디버깅 및 테스트 문제에 자주 직면합니다. 이러한 문제를 해결하기 위해 몇 가지 도구를 사용하여 더 나은 디버그 및 테스트에 도움을 줄 수 있습니다. 그중 Xdebug와 PHPUnit은 PHP 개발자에게 필수적인 두 가지 도구입니다. 이 기사에서는 중단점 디버깅 및 단위 테스트 사용 방법을 포함하여 Xdebug 및 PHPUnit의 기본 사용법을 소개합니다. Xdebug는 PHP용 디버거이자 분석기입니다. byX

PHP 서버 최적화에 대한 실용 가이드: 초보자부터 숙련까지 PHP 서버 최적화에 대한 실용 가이드: 초보자부터 숙련까지 Feb 19, 2024 pm 05:03 PM

1. PHP 서버 최적화 개요 PHP 서버 최적화란 서버 구성 조정, PHP 코드 최적화, 캐시 사용을 통해 PHP 서버의 성능과 안정성을 향상시키는 것을 말합니다. 일반적인 최적화 방법은 다음과 같습니다. 1. PHP 코드 최적화 PHP 코드 최적화는 PHP 서버 성능을 향상시키는 가장 직접적인 방법 중 하나입니다. PHP 코드를 최적화하는 방법에는 다음이 포함됩니다. 더 빠른 알고리즘과 데이터 구조를 사용하여 불필요한 데이터베이스 쿼리를 방지하고 캐싱 기술을 재활용하여 성능을 향상시킵니다. 코드 분석 도구를 사용하여 성능 병목 현상을 찾습니다. 2. PHP 서버 구성 최적화 PHP 서버 구성을 최적화하면 성능도 향상될 수 있습니다. PHP 서버 성능 그리고 안정성. PHP 서버 구성을 최적화하는 방법에는 PHP 메모리 제한 증가, PHP 프로세스 수 조정 및 최적화가 포함됩니다.

PHP 시작하기: Xdebug 디버깅 도구 PHP 시작하기: Xdebug 디버깅 도구 May 20, 2023 am 09:01 AM

PHP는 웹 애플리케이션 개발을 위해 널리 사용되는 오픈 소스 스크립팅 언어입니다. Xdebug는 뛰어난 PHP 디버깅 도구로, 많은 강력한 기능을 제공하며 대규모 웹 애플리케이션을 개발하고 디버깅하는 데 매우 적합합니다. 이 기사에서는 Xdebug의 개념과 이를 사용하여 PHP 코드를 디버깅하는 방법을 소개합니다. 1. Xdebug란 무엇입니까? PHP 개발 중에 개발자는 오류를 제거하기 위해 디버그해야 하는 경우가 많습니다. Xdebug는 뛰어난 PHP 디버깅입니다.

See all articles