No se puede conectar PhpStorm con xdebug con Docker
Tengo el siguiente Dockerfile:
FROM php:7.0-fpm-alpine
RUN apk add --update --virtual build_deps gcc g++ autoconf make &&\
docker-php-source extract &&\
pecl install xdebug &&\
echo "zend_extension=$(find /usr/local/lib/php/extensions/ -name xdebug.so)" > /usr/local/etc/php/conf.d/xdebug.ini \
&& echo "xdebug.remote_enable=1" >> /usr/local/etc/php/conf.d/xdebug.ini \
&& echo "xdebug.remote_autostart=0" >> /usr/local/etc/php/conf.d/xdebug.ini &&\
echo "xdebug.remote_connect_back=1" >> /usr/local/etc/php/conf.d/xdebug.ini &&\
echo "xdebug.remote_handler = dbgp" >> /usr/local/etc/php/conf.d/xdebug.ini &&\
echo "xdebug.remote_mode = req" >> /usr/local/etc/php/conf.d/xdebug.ini &&\
docker-php-ext-enable xdebug &&\
docker-php-source delete && \
apk del build_deps && \
rm -rf /var/cache/apk/* && \
rm -rf /tmp/*
ENTRYPOINT ["php-fpm"]
Y lo ejecuto con lo siguientedocker-compose.yml
:
version: '2'
services:
nginx_dev:
image: nginx:alpine
ports:
- "5092:5092"
links:
- "my_symfony_www_dev"
volumes:
- './conf/nginx/nginx_dev.conf:/etc/nginx/nginx.conf:ro'
- './logs/dev:/var/logs'
volumes_from:
- 'my_symfony_www_dev'
my_symfony_www_dev:
build:
context: .
dockerfile: Dockerfile_dev
image: "myimage/my_symfony_app:dev_php"
volumes:
- "$SOURCE_PATH:/var/www/html:Z"
environment:
- PHP_IDE_CONFIG= "serverName=my_symfony_www_dev"
- XDEBUG_CONFIG="remote_host=10.254.254.254,remote_port=9080"
- PHP_XDEBUG_ENABLED=1
También como se veahí Corro:
sudo ip addr add 10.254.254.254/24 brd + dev enp4s0 label enp4s0:1
Y configuró el IDE de PhpStorm así:
Luego en Firefox presiono elbotón y en PhpStorm presiono elbotón establezco un punto de interrupción sobre elapp_dev.php
Y no pasa nada.
Mi sistema escucha por el puerto9080
víanetstat -ntlp
comando donde escucha PhpStorm (PhpStorm es un servidor de acuerdo conesa respuesta)
tcp 0 0 0.0.0.0:9080 0.0.0.0:* LISTEN 4773/java
¿Tienes alguna idea de por qué sucede eso y cómo solucionarlo?
Editar 1:losphpinfo()
muestra:
También he configurado de cocker-compose.yml como:
version: '2'
services:
nginx_dev:
image: nginx:alpine
ports:
- "5092:5092"
links:
- "my_symfony_www_dev"
volumes:
- './conf/nginx/nginx_dev.conf:/etc/nginx/nginx.conf:ro'
- './logs/dev:/var/logs'
volumes_from:
- 'my_symfony_www_dev'
my_symfony_www_dev:
build:
context: .
dockerfile: Dockerfile_dev
image: "myimage/my_symfony_app:dev_php"
volumes:
- "$SOURCE_PATH:/var/www/html:Z"
environment:
- XDEBUG_CONFIG="remote_host=10.254.254.254,remote_port=9080"
- PHP_XDEBUG_ENABLED=1
Y mi dockerfile es:
FROM php:7.0-fpm-alpine
RUN apk add --update --virtual build_deps gcc g++ autoconf make &&\
docker-php-source extract &&\
pecl install xdebug &&\
echo "zend_extension=$(find /usr/local/lib/php/extensions/ -name xdebug.so)" > /usr/local/etc/php/conf.d/xdebug.ini \
&& echo "xdebug.remote_enable=1" >> /usr/local/etc/php/conf.d/xdebug.ini \
&& echo "xdebug.remote_autostart=0" >> /usr/local/etc/php/conf.d/xdebug.ini &&\
echo "xdebug.remote_connect_back=0" >> /usr/local/etc/php/conf.d/xdebug.ini &&\
echo "xdebug.remote_handler = dbgp" >> /usr/local/etc/php/conf.d/xdebug.ini &&\
echo "xdebug.remote_mode = req" >> /usr/local/etc/php/conf.d/xdebug.ini &&\
docker-php-ext-enable xdebug &&\
docker-php-source delete && \
apk del build_deps && \
rm -rf /var/cache/apk/* && \
rm -rf /tmp/*
ENTRYPOINT ["php-fpm"]
Aún el mismo resultado.