更新到WSL2后无法从PhpStorm连接到Xdebug

问题描述

环境

  • 操作系统:Windows 10 Pro 1909
  • WSL:Ubuntu(18.04。5)
  • PHP:7.3
  • PHPStorm:2020.2

我听说WSL2可以与1909一起使用,所以我将Ubuntu从WSL1升级到了2。 设置后尝试用PHPStorm进行调试时,“未建立连接”。已显示

然后我查看了日志,

[2640] Log opened at 2020 xx-xx: xx: xx
[2640] I: Connecting to configured address/port: localhost: 9001.
[2640] W: Creating socket for 'localhost: 9001',poll success,but error: Operation Now in progress (29).
[2640] E: Could not connect to client.: - (
[2640] Log closed at 2020 xx-xx: xx: xx

显示

我尝试更改各种Xdebug设置,但无法连接到其中任何一个

自WSL2起,IP地址有所不同,但是我听说现在可以使用localhost,因此我将其更改为localhost,但仍然无法正常工作。

当前无法使用WSL2吗?还是有什么办法? 预先谢谢你。

/etc/PHP/7.3/cli/PHP.ini:

[xdebug]
;extension_dir = "/usr/lib/PHP/20190902"                                           
;zend_extension = "/usr/lib/PHP/20190902/xdebug.so"
xdebug.remote_enable=1
xdebug.remote_autostart=1
xdebug.profiler_enable=1
xdebug.profiler_output_dir="/tmp"
xdebug.remote_enable=1
xdebug.remote_host="localhost"
xdebug.remote_port=9001
xdebug.remote_log=/var/log/xdebug.log
xdebug.idekey = "PHPSTORM"

/etc/PHP/7.3/cgi/conf.d/20-xdebug

zend_extension=xdebug.so
 
xdebug.remote_enable = 1
xdebug.remote_autostart = 1
xdebug.remote_port = 9001
xdebug.remote_host = "localhost"
xdebug.remote_log=/var/log/xdebug.log
xdebug.profiler_enable = 1
xdebug.profiler_output_dir = "/tmp"
xdebug.max_nesting_level = 1000
xdebug.idekey = "PHPSTORM"

PHPinfo:

PHP -info | grep -i xdebug                    
/etc/PHP/7.3/cli/conf.d/20-xdebug.ini,with Xdebug v2.9.6,copyright (c) 2002-2020,by Derick Rethans
xdebug
xdebug support => enabled
Support Xdebug on Patreon,GitHub,or as a business: https://xdebug.org/support
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.file_link_format => no value => no value
xdebug.filename_format => no value => no value
xdebug.force_display_errors => Off => Off
xdebug.force_error_reporting => 0 => 0
xdebug.gc_stats_enable => Off => Off
xdebug.gc_stats_output_dir => /tmp => /tmp
xdebug.gc_stats_output_name => gcstats.%p => gcstats.%p
xdebug.halt_level => 0 => 0
xdebug.idekey => PHPSTORM => PHPSTORM
xdebug.max_nesting_level => 1000 => 1000
xdebug.max_stack_frames => -1 => -1
xdebug.overload_var_dump => 2 => 2
xdebug.profiler_append => Off => Off
xdebug.profiler_enable => On => On
xdebug.profiler_enable_trigger => Off => Off
xdebug.profiler_enable_trigger_value => no value => no value
xdebug.profiler_output_dir => /tmp => /tmp
xdebug.profiler_output_name => cachegrind.out.%p => cachegrind.out.%p
xdebug.remote_addr_header => no value => no value
xdebug.remote_autostart => On => On
xdebug.remote_connect_back => Off => Off
xdebug.remote_cookie_expire_time => 3600 => 3600
xdebug.remote_enable => On => On
xdebug.remote_host => localhost => localhost
xdebug.remote_log => /var/log/xdebug.log => /var/log/xdebug.log
xdebug.remote_log_level => 7 => 7
xdebug.remote_mode => req => req
xdebug.remote_port => 9001 => 9001
xdebug.remote_timeout => 200 => 200
xdebug.scream => Off => Off
xdebug.show_error_trace => 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_enable_trigger_value => no value => no value
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

口译员:

enter image description here

调试:

enter image description here

解决方法

  • 您需要获取Windows主机的IP地址。您可以通过检查网络设置或在DOS提示符下(而不是WSL2内)通过ipconfig来完成此操作。
Ethernet adapter Ethernet:

Connection-specific DNS Suffix  . : Speedport_XXX
   IPv6 Address. . . . . . . . . . . : XXX
   Temporary IPv6 Address. . . . . . : XXX
   Temporary IPv6 Address. . . . . . : XXX
   Link-local IPv6 Address . . . . . : XXX
   IPv4 Address. . . . . . . . . . . : 192.168.2.115
   Subnet Mask . . . . . . . . . . . : 255.255.255.0
   Default Gateway . . . . . . . . . : fe80::1%8
                                       192.168.2.1

在我的示例中,IPv4地址的值为192.168.2.115

  • 在PhpStorm中转到设置>语言和框架> PHP>调试

  • 打开“高级设置”并启用“通过必需的已配置选项...”

  • 选择您的PHP> CLI解释器

  • 单击“配置选项”上的文件夹图标

  • 点击“加号”并添加新条目

  • 将其设置为键xdebug.remote_host

  • 将您的本地IP地址(192.168.2.115)设置为值

这将使WSL2中的Xdebug允许连接回Windows主机。

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...