在PhpStorm中使用xdebug通过Docker容器

时间:2017-05-31 11:09:10

标签: php docker phpstorm docker-compose xdebug

我已经阅读了一些有关此事的帖子,但在我的案例中没有任何帮助,或者只是忽略了丢失的部分。

我无法使用Docker容器让xdebug在PhpStorm上工作。

多克尔-compose.yml

version: '2'

services:
  web:
    image: nginx:latest
    volumes:
    - .:/usr/share/nginx/html
    - ./nginx/nginx.conf:/etc/nginx/nginx.conf
    - ./nginx/logs:/var/logs/nginx
    - ./nginx/site-enabled/default.conf:/etc/nginx/sites-enabled/default.conf
    ports:
    - "80:80"
    depends_on:
    - php

  db:
    image: mysql:5.7
    environment:
      MYSQL_ROOT_PASSWORD: 1234
      MYSQL_DATABASE: local_db
      MYSQL_USER: root
      MYSQL_PASSWORD: 1234
    ports:
    - "3306:3306"

  php:
    build: images/php
    volumes:
    - .:/usr/share/nginx/html
    - ./config/docker/php/php.ini:/usr/local/etc/php/php.ini
    - ./config/docker/php/ext-xdebug.ini:/usr/local/etc/php/conf.d/ext-xdebug.ini
    - ./config/docker/php/php-fpm.conf:/usr/local/etc/php-fpm.conf
    user: www-data
    depends_on:
    - db

配置/搬运工/ PHP / EXT-xdebug.ini

zend_extension="/usr/lib/php7/xdebug.so"
xdebug.remote_enable=1
xdebug.remote_port=9000
xdebug.overload_var_dump=1
xdebug.default_enable=1
xdebug.remote_autostart=1
xdebug.idekey=PHPSTORM
xdebug.remote_connect_back=1
xdebug.remote_host=172.20.0.1 # ip of host inside docker container
xdebug.remote_log=/usr/share/nginx/html/xdebug.log
来自xdebug.log的

错误

Log opened at 2017-05-31 11:01:14
I: Checking remote connect back address.
I: Checking header 'HTTP_X_FORWARDED_FOR'.
I: Checking header 'REMOTE_ADDR'.
I: Remote address found, connecting to 172.20.0.1:9000.
W: Creating socket for '172.20.0.1:9000', poll success, but error: Operation now in progress (29).
E: Could not connect to client. :-(
Log closed at 2017-05-31 11:01:14

在PhpStorm我正在使用具有以下设置的远程调试器:

服务器

Host - 127.0.0.1  
Port - 80 

服务器上的绝对路径

/usr/share/nginx/html

IDE会话密钥

PHPSTORM

2 个答案:

答案 0 :(得分:3)

好的,我在这里得到了解决方案

https://forums.docker.com/t/ip-address-for-xdebug/10460/9

我必须将内部IP设置为xdebug.remote_host并禁用xdebug.remote_connect_back=0

似乎这是一个osx的事情。 希望这可以帮助这里的人

答案 1 :(得分:3)

我发现ext-xdebug.ini上的以下配置适用于Mac版Docker

xdebug.remote_connect_back=0
xdebug.remote_host=host.docker.internal

Docker在容器内自动定义host.docker.internal。因此,我们只是指向xdebug认为host.docker.internal是主机的IP(显然是)。这样,我们不必依赖Docker容器和主机之间不断变化的内部IP。

更多信息,请点击https://docs.docker.com/docker-for-mac/networking/#use-cases-and-workarounds