Php 为什么Xdebug日志是空的?

Php 为什么Xdebug日志是空的?,php,xdebug,phpstorm,Php,Xdebug,Phpstorm,我正在尝试设置xdebug,这样我就可以从本地笔记本电脑上运行的phpstorm调试远程服务器上的php代码 它不起作用,但我认为开始解决问题的一个好地方是查看xdebug日志 遗憾的是,xdebug日志文件仍然是空的 我试图通过运行一个.php文件来测试xdebug,其中第一行是phpinfo() 运行该文件的结果给出了与xdebug相关的以下几行代码: xdebug support => enabled xdebug.auto_trace => Off => Off xde

我正在尝试设置xdebug,这样我就可以从本地笔记本电脑上运行的phpstorm调试远程服务器上的php代码

它不起作用,但我认为开始解决问题的一个好地方是查看xdebug日志

遗憾的是,xdebug日志文件仍然是空的

我试图通过运行一个.php文件来测试xdebug,其中第一行是phpinfo()

运行该文件的结果给出了与xdebug相关的以下几行代码:

xdebug support => enabled
xdebug.auto_trace => Off => Off
xdebug.cli_color => 0 => 0
xdebug.collect_assignments => Off => Off
xdebug.collect_includes => On => On
xdebug.collect_params => 0 => 0
xdebug.collect_return => Off => Off
xdebug.collect_vars => Off => Off
xdebug.coverage_enable => On => On
xdebug.default_enable => On => On
xdebug.dump.COOKIE => no value => no value
xdebug.dump.ENV => no value => no value
xdebug.dump.FILES => no value => no value
xdebug.dump.GET => no value => no value
xdebug.dump.POST => no value => no value
xdebug.dump.REQUEST => no value => no value
xdebug.dump.SERVER => no value => no value
xdebug.dump.SESSION => no value => no value
xdebug.dump_globals => On => On
xdebug.dump_once => On => On
xdebug.dump_undefined => Off => Off
xdebug.extended_info => On => On
xdebug.file_link_format => no value => no value
xdebug.idekey => PHPSTORM => PHPSTORM
xdebug.max_nesting_level => 100 => 100
xdebug.overload_var_dump => On => On
xdebug.profiler_aggregate => Off => Off
xdebug.profiler_append => Off => Off
xdebug.profiler_enable => Off => Off
xdebug.profiler_enable_trigger => Off => Off
xdebug.profiler_output_dir => /tmp => /tmp
xdebug.profiler_output_name => cachegrind.out.%p => cachegrind.out.%p
xdebug.remote_autostart => Off => Off
xdebug.remote_connect_back => Off => Off
xdebug.remote_cookie_expire_time => 3600 => 3600
xdebug.remote_enable => On => On
xdebug.remote_handler => dbgp => dbgp
xdebug.remote_host => 10.1.12.136 => 10.1.12.136
xdebug.remote_log => /home/mfowler/xdebug.log => /home/mfowler/xdebug.log
xdebug.remote_mode => req => req
xdebug.remote_port => 9000 => 9000
xdebug.scream => Off => Off
xdebug.show_exception_trace => Off => Off
xdebug.show_local_vars => Off => Off
xdebug.show_mem_delta => Off => Off
xdebug.trace_enable_trigger => Off => Off
xdebug.trace_format => 0 => 0
xdebug.trace_options => 0 => 0
xdebug.trace_output_dir => /tmp => /tmp
xdebug.trace_output_name => trace.%c => trace.%c
xdebug.var_display_max_children => 128 => 128
xdebug.var_display_max_data => 512 => 512
xdebug.var_display_max_depth => 3 => 3
_SERVER["PHP_SELF"] => xdebug_test.php
_SERVER["SCRIPT_NAME"] => xdebug_test.php
_SERVER["SCRIPT_FILENAME"] => xdebug_test.php
_SERVER["PATH_TRANSLATED"] => xdebug_test.php
但是/home/mfowler/xdebug.log中没有任何内容


感谢大家的帮助

检查正确的日志配置,我更喜欢最大日志级别:

用于Xdebug 2

# always start
xdebug.remote_autostart=true
# log settings
xdebug.remote_log="/tmp/xdebug/xdebug.log"
xdebug.remote_log_level=7
用于Xdebug 3

# always start
xdebug.start_with_request=yes
# log settings
xdebug.log="/tmp/xdebug/xdebug.log"
xdebug.log_level=7
请确保已创建并访问日志文件,即:

mkdir -p /tmp/xdebug
touch /tmp/xdebug/xdebug.log
chmod 777 /tmp/xdebug/xdebug.log

要检查远程端口是否正在侦听-请使用telnet:

telnet 10.1.12.136 9000

您是说本地文件是空的,还是远程文件是空的?您可能需要检查您正在使用的远程接收器是否正在工作/连接。对于本地,请确保探查器_enable处于启用状态。这可能是因为xdebug没有看到参与的理由(例如没有特殊的xdebug cookie或GET/POST参数)?设置
xdebug.remote_autostart=1
或放置
xdebug_break()并重试。另外,请确保日志文件位置可由任何人写入。xdebug.remote_autostart=1为我完成了此操作,日志现在已填充,谢谢!通过本地主机(在远程服务器上)成功连接到debugclient。现在只需想办法让xdebug远程连接到我的笔记本电脑上……
xdebug.remote\u autostart=1
也帮了我一把