【问题标题】:Xdebug and Atom does not work after upgrade to MacOs Mojave升级到 MacOs Mojave 后 Xdebug 和 Atom 不起作用
【发布时间】:2019-06-05 20:34:16
【问题描述】:

升级到 mac-os Mojave 后,Atom (v1.34.0) 的 Xdebug (v2.6.1) 不再工作(根本不会触发断点)。 我能够使用 High Sierra 成功配置它,但升级后我遇到了 apache2 的 httpd.conf 问题(我修复了它)并且 Xdebug 不再工作。

尽管我找到了很多与此主题相关的答案,但对我来说没有任何一个有用。

如您所见,Xdebug 已正确安装


    MacBook-Pro-6:~ francesco$ php -v
    PHP 7.1.13 (cli) (built: Feb  1 2018 13:38:42) ( NTS )
    Copyright (c) 1997-2017 The PHP Group
    Zend Engine v3.1.0, Copyright (c) 1998-2017 Zend Technologies
        with Zend OPcache v7.1.13, Copyright (c) 1999-2017, by Zend Technologies
        with Xdebug v2.6.1, Copyright (c) 2002-2018, by Derick Rethans

这是配置设置的完整列表


    MacBook-Pro-6:~ francesco$ php -i | grep xdebug
    /usr/local/php5/php.d/50-extension-xdebug.ini,
    xdebug
    xdebug support => enabled
    IDE Key => xdebug.atom
    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.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 => /var/tmp/ => /var/tmp/
    xdebug.gc_stats_output_name => gcstats.%p => gcstats.%p
    xdebug.halt_level => 0 => 0
    xdebug.idekey => xdebug.atom => xdebug.atom
    xdebug.max_nesting_level => 256 => 256
    xdebug.max_stack_frames => -1 => -1
    xdebug.overload_var_dump => 2 => 2
    xdebug.profiler_aggregate => Off => Off
    xdebug.profiler_append => Off => Off
    xdebug.profiler_enable => Off => Off
    xdebug.profiler_enable_trigger => On => On
    xdebug.profiler_enable_trigger_value => no value => no value
    xdebug.profiler_output_dir => /var/tmp/ => /var/tmp/
    xdebug.profiler_output_name => xdebug-profile-cachegrind.out-%H-%R => xdebug-profile-cachegrind.out-%H-%R
    xdebug.remote_addr_header => no value => no value
    xdebug.remote_autostart => Off => Off
    xdebug.remote_connect_back => On => On
    xdebug.remote_cookie_expire_time => 3600 => 3600
    xdebug.remote_enable => On => On
    xdebug.remote_handler => dbgp => dbgp
    xdebug.remote_host => 127.0.0.1 => 127.0.0.1
    xdebug.remote_log => no value => no value
    xdebug.remote_mode => req => req
    xdebug.remote_port => 9000 => 9000
    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 => /var/tmp/ => /var/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

如您所见,xdebug 已启用


    xdebug support => enabled 

ide 键是 xdebug.atom


    IDE Key => xdebug.atom

xdebug.ini的具体路径在


    /usr/local/php5/php.d/50-extension-xdebug.ini

这就是它的内容


    zend_extension=/usr/local/php5/lib/php/extensions/no-debug-non-zts-20160303/xdebug.so
    [xdebug]
    xdebug.idekey = xdebug.atom
    xdebug.remote_enable=1
    xdebug.remote_host=127.0.0.1
    xdebug.remote_connect_back=1    # Not safe for production servers
    xdebug.remote_port=9000
    xdebug.remote_handler=dbgp
    xdebug.remote_mode=req
    xdebug.remote_autostart=false
    xdebug.profiler_enable_trigger=1
    xdebug.profiler_output_name=xdebug-profile-cachegrind.out-%H-%R
    xdebug.var_display_max_children = 128
    xdebug.var_display_max_data = 512
    xdebug.var_display_max_depth = 3

顺便说一句,我还尝试配置预安装在 /usr/lib/php/extensions/no-debug-non-zts-20160303/xdebug.so 的 xdebug 扩展,但没有成功。

xdebug.remote_autostart = false 因为我有 Xdebug Helper for Chrome 并且 ide.key 设置为 xdebug.atom

我为 Atom 安装了 php-debug 包,这是我的 config.json


    "php-debug":
        ServerPort: 9000
        PathMaps: [
        "/remote/path;/local/path"
        "/Library/WebServer/repositories;/Library/WebServer/repositories"
        ]
        showWelcome: false

我的远程和本地路径是相同的,因为我需要调试我的本地主机。我不确定将本地路径配置为远程路径是否是一个错误,但我记得在 High Sierra Atom 中给了我关于如何配置路径的建议,并且无论如何都会触发断点,所以我相信这不是问题。

我尝试删除 paths,添加字段 ServerAddress,删除字段 ServerPort,但没有成功。

当然,每次修改时我都会重启 apache。

根本没有触发断点,我不知道该怎么办。

你对此有什么想法吗?非常感谢。

As LazyOne 指出httpd.conf中Apache加载的php7是预装Mojave的版本

LoadModule php7_module libexec/apache2/libphp7.so

不是我安装的PHP 7.1.13 (cli)

如果我再次尝试设置

LoadModule php7_module /usr/local/php5-7.1.13-20180201-134129/libphp7.so

然后服务器无法启动,sudo apachectl configtest 我可以看到:

httpd: Syntax error on line 176 of /private/etc/apache2/httpd.conf: 
Cannot load /usr/local/php5-7.1.13-20180201-134129/libphp7.so into 
server: dlopen(/usr/local/php5-7.1.13-20180201-134129/libphp7.so, 10): 
no suitable image found.  Did find:\n\t/usr/local/php5-7.1.13- 
20180201-134129/libphp7.so: code signature in (/usr/local/php5-7.1.13- 
20180201-134129/libphp7.so) not valid for use in process using Library 
Validation: mapped file has no cdhash, completely unsigned? Code has 
to be at least ad-hoc signed.\n\t/usr/local/php5-7.1.13-20180201- 
134129/libphp7.so: stat() failed with errno=22

按照这个答案Apache not working after macOS Mojave update

我尝试像这样将文件替换为/usr/libexec/apache2/ sudo cp /usr/local/php5-7.1.13-20180201-134129/libphp7.so /usr/libexec/apache2/

但在终端上我总是 cp: /usr/libexec/apache2/libphp7.so: Operation not permitted

我按照这里提到的所有步骤 http://osxdaily.com/2018/10/09/fix-operation-not-permitted-terminal-error-macos/

但还是Operation not permitted

你知道php -v中显示的php7如何配置吗?

【问题讨论】:

  • 您的php -v 显示PHP 7.1.13 .. 而您正在编辑PHP 5 的设置(基于/usr/local/php5/... 文件路径。这可能是原因。请检查phpinfo()php -i输出——在最顶部它应该列出它已经解析的所有配置文件..所以你可以验证你正在编辑正确的配置文件。
  • 我认为这不是问题,您也可以在这里看到coolestguidesontheplanet.com/upgrade-php-on-osx
  • 这很好..但是您是否仔细检查过您正在编辑正确的配置文件,即您的 PHP 版本使用的配置文件?另请注意,CLI 环境和 Apache 使用的 php.ini 文件可能不同(在 Mac 和 Linux 上很常见)。
  • 你是对的,谢谢你,但它仍然无法正常工作!现在我有新问题(我编辑了问题以更好地解释)

标签: atom-editor xdebug macos-mojave


【解决方案1】:

基本上问题出在这个https://github.com/liip/php-osx/issues/249 因为 Mojave 替换了内置 Apache 的 httpd.conf(创建 httpd.conf~previous 作为先前配置的备份)我的 apache 指向另一个版本的 php7 (/usr/libexec/apache2/ 中内置的 Mojave)。

CLI 中php7 的php.iniXdebug 扩展。 Mojave 内置的 php7 的 php.ini 没有。

这就是为什么我的调试器不工作但服务器工作,它指向一个功能版本的 php7 但没有 Xdebug 的扩展。

我可以重命名旧文件 httpd.conf~previous 以反转所有以前的工作设置(我在/usr/local/php5-7.1.13-20180201-134129 中安装的 php7 版本)但是...... Mojave 中内置 Apache 来读取外部库(这似乎是一个需要苹果解决的问题),因此在 CLI 中指向我的版本 php7 不起作用。

httpd: Syntax error on line 176 of /private/etc/apache2/httpd.conf: 
Cannot load /usr/local/php5-7.1.13-20180201-134129/libphp7.so into 
server: dlopen(/usr/local/php5-7.1.13-20180201-134129/libphp7.so, 10): 
no suitable image found.

是输入sudo apachectl configtest的响应

要解决此问题,我必须将文件 /usr/local/php5-7.1.13-20180201-134129/libphp7.so 复制到 /usr/libexec/apache2/,但如前所述,我总是从终端得到 Operation not permitted

这是因为文件夹/usr 受到MacOs 的系统完整性保护 的保护,仅仅给予终端全盘访问权限 是不够的。

我必须在 Recovery Mode 下重新启动系统并使用 csrutil disable 从终端禁用 SIP。

我按照这个教程来做这个http://osxdaily.com/2015/10/05/disable-rootless-system-integrity-protection-mac-os-x/

禁用 SIP 后,我终于能够在 apache 中复制 php7 lib sudo cp /usr/local/php5-7.1.13-20180201-134129/libphp7.so /usr/libexec/apache2/

然后重新启动 apache 服务器,最后 Atom 中的调试器再次工作。

为了安全起见,我在 Recovery Mode 中再次启用了 SIP,使用 csrutil enable

【讨论】:

    猜你喜欢
    • 2017-08-29
    • 2019-03-02
    • 2020-03-07
    • 2016-04-08
    • 2019-09-22
    • 2018-11-29
    • 1970-01-01
    • 2019-03-08
    • 1970-01-01
    相关资源
    最近更新 更多