Моя среда:
На Mac я использую виртуальную машину Debian (jessie) с Apache2 2.4.10, PHP 5.6.9 и Xdebug 2.3.3.
У виртуальной машины есть собственный IP-адрес в моей локальной сети, и в файле хостов Mac я ввел для нее имя хоста, поэтому веб-сайт в виртуальной машине доступен через имя хоста; поэтому я настроил vhost в Apache.
Что я пытаюсь сделать:
Мне нужно отладить мой проект PHP на удаленном сервере (ВМ). Поэтому я следовал инструкциям, которые нашел в Интернете. Но, к сожалению, Xdebug никогда не пытается подключиться к remote_host.
Еще несколько фактов:
мой [xdebug]
раздел в моем php.ini
:
[Xdebug]
; this is commented out, because i received warnings in apache's error.log, that it is allready activated somewhere else
; I found a site in the Web, where somebody says, that this means, the extension is already compiled into my php binary
; even with this line active I face the same behavior
;zend_extension = /usr/lib/php5/20131226/xdebug.so
xdebug.remote_enabled = 1
; this is comented out, because i activated remote_connect_back
;xdebug.remote_host = 192.168.2.106
xdebug.remote_mode = req
xdebug.remote_connect_back = 1
xdebug.remote_autostart = 1
xdebug.remote_port = 9000
xdebug.idekey = PHPSTORM
xdebug.remote_log = /var/log/apache2/xdebug_log
xdebug
раздел из вывода из php -i
:
xdebug
xdebug support => enabled
Version => 2.3.3
IDE Key => root
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.force_display_errors => Off => Off
xdebug.force_error_reporting => 0 => 0
xdebug.halt_level => 0 => 0
xdebug.idekey => no value => no value
xdebug.max_nesting_level => 256 => 256
xdebug.max_stack_frames => -1 => -1
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_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_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_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
Так как я хочу отладить с помощью PHPStorm, но он не получает отладочный запрос при перезагрузке сайта, я решил проследить связь TCP. Поэтому в ВМ я назвал следующее:
tcpdump -ni eth0 -n port 9000 -X
Но, к сожалению, я никогда не получаю никаких пакетов относительно порта 9000.
Кроме того, я сделал тест с Netcat на порт 9000:
netcat 192.168.2.106 9000
Теперь tcpdump показывает пакеты, загружаемые с клиента на порт 9000, и, если PHPStorm не прослушивает, netcat сообщает мне, что в соединении отказано.
Таким образом, после целого дня поиска в Google (вчера) я не мог определить свою проблему. Пожалуйста, кто-нибудь может направить мой нос в правильном направлении.
Что я делаю неправильно?
И извините за мой плохой английский.
Задача ещё не решена.
Других решений пока нет …