【问题标题】:xdebug ini settings not appliedxdebug ini 设置未应用
【发布时间】:2016-02-25 17:28:23
【问题描述】:

我在 ubuntu 14.04 上与厨师一起设置了自定义灯组。

问题是来自 xdebug.ini.erb 的设置不适用于 php.ini。

我使用包提供程序包“php5-xdebug”与厨师一起安装了 xdebug 之后,我在 phpinfo 的其他已解析 ini 文件中看到了 xdebug。

我并不完全同意,但我认为只要添加行 zend_extension = path/xdebug.so xdebug 不再列为附加的已解析 ini 文件,并且对 xdebug.ini.erb 所做的设置不会生效。

这是我的 phpinfo xdebug 部分的一部分

xdebug support  enabled
Version     2.2.3
IDE Key     no value

Supported protocols Revision
DBGp - Common DeBuGger Protocol     $Revision: 1.145 $

Directive   Local Value Master Value
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   no value    no value
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    Off Off
xdebug.remote_handler   dbgp    dbgp
xdebug.remote_host  localhost   localhost
xdebug.remote_log   no value    no value
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

我的 xdebug.ini.erb 如下所示:

zend_extension = /usr/lib/php5/20121212/xdebug.so"
xdebug.remote_host = localhost
xdebug.remote_enable = On
xdebug.remote_mode=req
xdebug.remote_connect_back = On
xdebug.remote_port = 9000
xdebug.remote_handler = "dbgp"
xdebug.profiler_enable = Off
xdebug.profiler_enable_trigger = On

我可以看到 xdebug 正在通过具有不同样式的 var_dump 函数工作。只有 ini.erb 设置未应用。 这是我的厨师代码:

# php5-dev is need for xdebug to have phpize ready
needed = ['php5-mysql', 'php5-mcrypt', 'php-pear', 'php5', 'php5-dev']

additional_packages = ['php5-curl', 'php5-gd', 'php5-intl', 'php5-imagick', 'php5-imap', 'memcached', 'php5-memcached', 'php5-ming', 'php5-xmlrpc', 'php5-xsl', 'php5-xdebug']

needed.each() do |pkg|
    package pkg
end

if node['install']['additional_php_packages'] == true
   additional_packages.each() do |apk|
      package apk
   end
end

template '/etc/php5/mods-available/xdebug.ini' do
    source 'xdebug.ini.erb'
end

【问题讨论】:

    标签: php chef-infra xdebug


    【解决方案1】:

    解决方案是不编写新的 xdebug.ini,而是编辑安装期间自动生成的 xdebug.ini Chef::File::Edit and insert_line_if_no_match(xdebug.remote_enable = on)

    【讨论】:

    • 对于发现此问题的其他人,强烈建议不要使用FileEdit,因为它在大多数情况下会产生非常脆弱的代码。 line 食谱提供了更强大的选项,但不是很多。
    • 根本原因是你在 mods-available 中创建了一个文件,而不是将它的 sim 链接到 mods-enabled ... 我不知道你使用哪个发行版,如果你的 php.ini 真的包括 mods-enabled/* 或 mods-enabled/*.ini 或之前的系统状态是什么,但我敢打赌,你真正的问题是只管理系统的一部分,并假设它之前的状态,这是错误的模式 IMO。
    • @Tensibai 安装 php5-xdebug 会在 mods-available 中创建一个 xdebug.ini 并在 php5/apache2/conf.d/ 中创建一个指向该文件的符号链接。可能只是编写一个新的ini文件,厨师足够聪明地删除符号链接,因为它指向不同的元数据?像 php 的 a2enmod 这样的东西会很棒。 ;)
    • 我只是认为这是最后重新加载apache的问题,包安装应该这样做......
    猜你喜欢
    • 1970-01-01
    • 2011-01-03
    • 1970-01-01
    • 2013-07-28
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多