I\'ve been working with ddev on my Drupal projects, and now want to use xdebug so I have step-debugging with PhpStorm (or really any IDE would be fine). But I can\'t seem to
Debugging xdebug in any setup can be a little trouble, but here are the steps to take:
ddev exec enable_xdebug
to enable it when they want it, and ddev exec disable_xdebug
when they're done with it, but it can also be enabled in .ddev/config.yaml
.ddev ssh
into the web container. Can you ping host.docker.internal
(and get responses)? If you can't, you might have an over-aggressive firewall.ddev ssh
: Can telnet host.docker.internal 9000
connect? If it does, you have something else running on port 9000, probably php-fpm. Use lsof -i :9000 -sTCP:LISTEN
to find out what is there and stop it, or change the xdebug port and configure PHPStorm to use the new one . Don't continue until your telnet command does not connect.ddev ssh
and try the telnet host.docker.internal 9000
again. It should connect. If not, maybe PHPStorm is not listening, or not configured to listen on port 9000?php -i | grep grep Xdebug
inside the container, or use any other technique you want that gives the output of phpinfo()
, including Drupal's admin/reports/status/php. You should see with Xdebug v2.9.6, Copyright (c) 2002-2020
and php -i | grep "xdebug.remote_enable"
should give you xdebug.remote_enable: On
.A note from @heddn: If you want to have xdebug running only for fpm, phpenmod -s fpm xdebug
for example, instead of running enable_xdebug
.
A note from @mfrieling: If you use a browser extension like XDebug Helper which sets an IDE key, that must be the same as on the server. Since DDEV 1.10.0 "there's a real user created for you inside the web and db containers, with your username and userid" which is also used as IDE key by default. The used IDE key must be the same on the server, the browser extension/cookie sent and PHPStorm. You can change the IDE key in DDEV by creating a file .ddev/php/xdebug.ini
with the following two lines (replace PHPSTORM
with the value you want use:
[XDebug]
xdebug.idekey = PHPSTORM
Your followups are welcome here!