2018-07-03 15:47:58 +02:00
|
|
|
.. _configure_php_xdebug:
|
2018-04-08 12:20:00 +02:00
|
|
|
|
2018-07-03 15:47:58 +02:00
|
|
|
********************
|
|
|
|
Configure PHP Xdebug
|
|
|
|
********************
|
2018-04-08 12:20:00 +02:00
|
|
|
|
|
|
|
This tutorial shows you how to enable and use Xdebug with the Devilbox.
|
|
|
|
|
|
|
|
.. seealso::
|
2018-07-03 15:47:58 +02:00
|
|
|
|
2018-06-03 20:45:01 +02:00
|
|
|
If you are unsure of how to add custom ``*.ini`` files to the Devilbox,
|
|
|
|
have a look at this section first: :ref:`php_ini`
|
2018-04-08 12:20:00 +02:00
|
|
|
|
|
|
|
|
|
|
|
**Table of Contents**
|
|
|
|
|
|
|
|
.. contents:: :local:
|
|
|
|
|
|
|
|
Enable Xdebug
|
|
|
|
=============
|
|
|
|
|
|
|
|
This section shows you the minimum required ``*.ini`` ini settings to get xdebug to work with
|
|
|
|
the Devilbox. It will also highlight the differences between operating system and Docker versions.
|
|
|
|
|
|
|
|
.. seealso:: See here for how to add the ``*.ini`` values to the Devilbox: :ref:`php_ini`.
|
|
|
|
|
|
|
|
Once you have configured Xdebug, you can verify it at the Devilbox intranet:
|
|
|
|
http://localhost/info_php.php
|
|
|
|
|
|
|
|
|
|
|
|
Required for all OS
|
|
|
|
-------------------
|
|
|
|
|
|
|
|
Additionally to the specific configurations for each operating system and Docker version you will
|
|
|
|
probably also want to add the following to your ini file:
|
|
|
|
|
|
|
|
.. code-block:: ini
|
2018-06-03 19:16:22 +02:00
|
|
|
:caption: xdebug.ini
|
2018-04-08 12:20:00 +02:00
|
|
|
|
2018-06-03 19:16:22 +02:00
|
|
|
xdebug.default_enable=1
|
|
|
|
xdebug.remote_enable=1
|
|
|
|
xdebug.remote_handler=dbgp
|
|
|
|
xdebug.remote_port=9000
|
|
|
|
xdebug.remote_autostart=1
|
|
|
|
xdebug.idekey="PHPSTORM"
|
|
|
|
xdebug.remote_log=/var/log/php/xdebug.log
|
2018-04-08 12:20:00 +02:00
|
|
|
|
2018-04-10 09:32:06 +02:00
|
|
|
.. seealso:: https://xdebug.org/docs/all_settings
|
|
|
|
|
|
|
|
default_enable
|
|
|
|
^^^^^^^^^^^^^^
|
|
|
|
By enabling this, stacktraces will be shown by default on an error event.
|
|
|
|
It is advisable to leave this setting set to 1.
|
|
|
|
|
|
|
|
remote_enable
|
|
|
|
^^^^^^^^^^^^^
|
|
|
|
This switch controls whether Xdebug should try to contact a debug client which is listening on the
|
|
|
|
host and port as set with the settings ``xdebug.remote_host`` and ``xdebug.remote_port``.
|
|
|
|
If a connection can not be established the script will just continue as if this setting was 0.
|
|
|
|
|
|
|
|
remote_handler
|
|
|
|
^^^^^^^^^^^^^^
|
|
|
|
Can be either ``'php3'`` which selects the old PHP 3 style debugger output, ``'gdb'`` which enables
|
|
|
|
the GDB like debugger interface or ``'dbgp'`` - the debugger protocol. The DBGp protocol is the only
|
|
|
|
supported protocol.
|
|
|
|
|
|
|
|
**Note:** Xdebug 2.1 and later only support ``'dbgp'`` as protocol.
|
|
|
|
|
|
|
|
remote_port
|
|
|
|
^^^^^^^^^^^
|
|
|
|
The port to which Xdebug tries to connect on the remote host. Port ``9000`` is the default for both
|
|
|
|
the client and the bundled debugclient. As many clients use this port number, it is best to leave
|
|
|
|
this setting unchanged.
|
|
|
|
|
|
|
|
remote_autostart
|
|
|
|
^^^^^^^^^^^^^^^^
|
|
|
|
Normally you need to use a specific HTTP GET/POST variable to start remote debugging (see
|
|
|
|
`Remote Debugging <https://xdebug.org/docs/remote#browser_session>`_). When this setting is set to
|
|
|
|
``1``, Xdebug will always attempt to start a remote debugging session and try to connect to a client,
|
|
|
|
even if the GET/POST/COOKIE variable was not present.
|
|
|
|
|
|
|
|
idekey
|
|
|
|
^^^^^^
|
|
|
|
Controls which IDE Key Xdebug should pass on to the DBGp debugger handler. The default is based on
|
|
|
|
environment settings. First the environment setting DBGP_IDEKEY is consulted, then USER and as last
|
|
|
|
USERNAME. The default is set to the first environment variable that is found. If none could be found
|
|
|
|
the setting has as default ''. If this setting is set, it always overrides the environment variables.
|
|
|
|
|
|
|
|
For the sake of this tutorial we are going to use ``PHPSTORM`` as an example value.
|
|
|
|
|
2018-04-08 12:20:00 +02:00
|
|
|
remote_log
|
|
|
|
^^^^^^^^^^
|
|
|
|
Keep the exact path of ``/var/log/php/xdebug.log``. You will then have the log file available
|
|
|
|
in the Devilbox log directory of the PHP version for which you have configured Xdebug.
|
|
|
|
|
|
|
|
.. important::
|
2018-06-03 19:16:22 +02:00
|
|
|
You can set the value of ``xdebug.idekey`` to whatever you like, however it is important
|
|
|
|
to remember what value you have set. Throughout the examples in this tutorial it is assumed,
|
|
|
|
that the value is ``PHPSTORM``.
|
2018-04-08 12:20:00 +02:00
|
|
|
|
|
|
|
|
|
|
|
Linux
|
|
|
|
-----
|
|
|
|
|
|
|
|
.. code-block:: ini
|
2018-06-03 19:16:22 +02:00
|
|
|
:caption: xdebug.ini
|
|
|
|
:emphasize-lines: 1
|
2018-04-08 12:20:00 +02:00
|
|
|
|
2018-06-03 19:16:22 +02:00
|
|
|
xdebug.remote_connect_back=1
|
2018-04-08 12:20:00 +02:00
|
|
|
|
|
|
|
|
|
|
|
MacOS (Docker for Mac)
|
|
|
|
----------------------
|
|
|
|
|
|
|
|
Docker 18.03.0-ce+ and Docker compose 1.20.1+
|
|
|
|
|
|
|
|
.. code-block:: ini
|
2018-06-03 19:16:22 +02:00
|
|
|
:caption: xdebug.ini
|
|
|
|
:emphasize-lines: 1
|
2018-04-08 12:20:00 +02:00
|
|
|
|
2018-06-03 19:16:22 +02:00
|
|
|
xdebug.remote_host=host.docker.internal
|
|
|
|
xdebug.remote_connect_back=0
|
2018-04-08 12:20:00 +02:00
|
|
|
|
|
|
|
Docker 17.12.0-ce+ and Docker compose 1.18.0+
|
|
|
|
|
|
|
|
.. code-block:: ini
|
2018-06-03 19:16:22 +02:00
|
|
|
:caption: xdebug.ini
|
|
|
|
:emphasize-lines: 1
|
2018-04-08 12:20:00 +02:00
|
|
|
|
2018-06-03 19:16:22 +02:00
|
|
|
xdebug.remote_host=docker.for.mac.host.internal
|
|
|
|
xdebug.remote_connect_back=0
|
2018-04-08 12:20:00 +02:00
|
|
|
|
|
|
|
Docker 17.06.0-ce+ and Docker compose 1.14.0+
|
|
|
|
|
|
|
|
.. code-block:: ini
|
2018-06-03 19:16:22 +02:00
|
|
|
:caption: xdebug.ini
|
|
|
|
:emphasize-lines: 1
|
2018-04-08 12:20:00 +02:00
|
|
|
|
2018-06-03 19:16:22 +02:00
|
|
|
xdebug.remote_host=docker.for.mac.localhost
|
|
|
|
xdebug.remote_connect_back=0
|
2018-04-08 12:20:00 +02:00
|
|
|
|
|
|
|
If you have older versions, upgrade.
|
|
|
|
|
|
|
|
|
|
|
|
MacOS (Docker Toolbox)
|
|
|
|
----------------------
|
|
|
|
|
|
|
|
.. warning::
|
2018-06-03 19:16:22 +02:00
|
|
|
This is a legacy solution, upgrade to Docker for Mac
|
|
|
|
https://docs.docker.com/toolbox
|
2018-04-08 12:20:00 +02:00
|
|
|
|
|
|
|
|
|
|
|
Windows (Docker for Windows)
|
|
|
|
----------------------------
|
|
|
|
|
|
|
|
Docker 18.03.0-ce+ and Docker compose 1.20.1+
|
|
|
|
|
|
|
|
.. code-block:: ini
|
2018-06-03 19:16:22 +02:00
|
|
|
:caption: xdebug.ini
|
|
|
|
:emphasize-lines: 1
|
2018-04-08 12:20:00 +02:00
|
|
|
|
2018-06-03 19:16:22 +02:00
|
|
|
xdebug.remote_host=docker.for.win.host.internal
|
|
|
|
xdebug.remote_connect_back=0
|
2018-04-08 12:20:00 +02:00
|
|
|
|
|
|
|
Docker 17.06.0-ce+ and Docker compose 1.14.0+
|
|
|
|
|
|
|
|
.. code-block:: ini
|
2018-06-03 19:16:22 +02:00
|
|
|
:caption: xdebug.ini
|
|
|
|
:emphasize-lines: 1
|
2018-04-08 12:20:00 +02:00
|
|
|
|
2018-06-03 19:16:22 +02:00
|
|
|
xdebug.remote_host=docker.for.win.host.localhost
|
|
|
|
xdebug.remote_connect_back=0
|
2018-04-08 12:20:00 +02:00
|
|
|
|
|
|
|
If you have older versions, upgrade.
|
|
|
|
|
2018-04-10 09:32:06 +02:00
|
|
|
|
2018-04-08 12:20:00 +02:00
|
|
|
Windows (Docker Toolbox)
|
|
|
|
------------------------
|
|
|
|
|
|
|
|
.. warning::
|
2018-06-03 19:16:22 +02:00
|
|
|
This is a legacy solution, upgrade to Docker for Windows
|
|
|
|
https://docs.docker.com/toolbox
|
2018-04-08 12:20:00 +02:00
|
|
|
|
|
|
|
|
|
|
|
Configure your IDE
|
|
|
|
==================
|
|
|
|
|
2018-04-10 09:32:06 +02:00
|
|
|
Required for all IDE
|
|
|
|
--------------------
|
|
|
|
|
|
|
|
Path mapping
|
|
|
|
^^^^^^^^^^^^
|
|
|
|
The path mapping is a mapping between the file path on your host operating system and the one
|
|
|
|
inside the PHP Docker container.
|
|
|
|
|
|
|
|
The path on your host operating system is the one you have set in :ref:`env_httpd_datadir`.
|
|
|
|
In case you have set a relative path in ``.env``, ensure to retrieve the absolute path of it when
|
|
|
|
setting up your IDE config.
|
|
|
|
|
|
|
|
The path inside the PHP Docker container is always ``/shared/httpd``.
|
|
|
|
|
|
|
|
.. important::
|
2018-06-03 19:16:22 +02:00
|
|
|
Even though your path in ``.env`` for :ref:`env_httpd_datadir` might be relative (e.g. ``./data/www``),
|
|
|
|
you need to get the actualy absolute path of it, when setting up your IDE.
|
2018-04-10 09:32:06 +02:00
|
|
|
|
|
|
|
IDE key
|
|
|
|
^^^^^^^
|
|
|
|
This is the value you have set in ``xdebug.ini`` for ``xdebug.idekey``. In the example of this
|
|
|
|
tutorial, the value was set to ``PHPSTORM``.
|
|
|
|
|
|
|
|
Port
|
|
|
|
^^^^
|
|
|
|
This is the value you have set in ``xdebug.ini`` for ``xdebug.remote_port``. In the example of this
|
|
|
|
tutorial, the value was set to ``9000``.
|
|
|
|
|
2018-04-08 12:20:00 +02:00
|
|
|
|
|
|
|
Atom
|
|
|
|
----
|
|
|
|
|
2018-04-10 09:32:06 +02:00
|
|
|
1. Install `php-debug <https://atom.io/packages/php-debug>`_
|
|
|
|
2. Configure ``config.cson`` (File -> Config...)
|
|
|
|
3. Adjust your ``xdebug.ini``
|
|
|
|
|
|
|
|
For Atom, you need to provide a different ``xdebug.idekey`` in your php.ini file ``xdebug.ini``:
|
|
|
|
|
|
|
|
.. code-block:: ini
|
2018-06-03 19:16:22 +02:00
|
|
|
:caption: xdebug.ini
|
2018-04-10 09:32:06 +02:00
|
|
|
|
2018-06-03 19:16:22 +02:00
|
|
|
xdebug.idekey=xdebug.atom
|
2018-04-10 09:32:06 +02:00
|
|
|
|
|
|
|
|
2018-04-08 12:20:00 +02:00
|
|
|
Linux
|
|
|
|
^^^^^^
|
2018-06-03 19:16:22 +02:00
|
|
|
.. code-block:: js
|
|
|
|
:caption: launch.json
|
|
|
|
:emphasize-lines: 6
|
|
|
|
|
|
|
|
"php-debug":
|
|
|
|
{
|
|
|
|
ServerPort: 9000
|
|
|
|
PathMaps: [
|
|
|
|
"remotepath;localpath"
|
|
|
|
"/shared/httpd;/home/cytopia/repo/devilbox/data/www"
|
|
|
|
]
|
|
|
|
}
|
2018-04-08 12:20:00 +02:00
|
|
|
|
|
|
|
MacOS (Docker for Mac)
|
|
|
|
^^^^^^^^^^^^^^^^^^^^^^
|
2018-04-10 09:32:06 +02:00
|
|
|
.. todo:: Help needed. Please provide your config.
|
2018-04-08 12:20:00 +02:00
|
|
|
|
|
|
|
MacOS (Docker Toolbox)
|
|
|
|
^^^^^^^^^^^^^^^^^^^^^^
|
2018-04-10 09:32:06 +02:00
|
|
|
.. todo:: Help needed. Please provide your config.
|
2018-04-08 12:20:00 +02:00
|
|
|
|
|
|
|
Windows (Docker for Windows)
|
|
|
|
^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
2018-04-10 09:32:06 +02:00
|
|
|
.. todo:: Help needed. Please provide your config.
|
2018-04-08 12:20:00 +02:00
|
|
|
|
|
|
|
Windows (Docker Toolbox)
|
|
|
|
^^^^^^^^^^^^^^^^^^^^^^^^
|
2018-04-10 09:32:06 +02:00
|
|
|
.. todo:: Help needed. Please provide your config.
|
2018-04-08 12:20:00 +02:00
|
|
|
|
|
|
|
|
|
|
|
PHPStorm
|
|
|
|
--------
|
|
|
|
|
|
|
|
Linux
|
|
|
|
^^^^^^
|
2018-04-11 08:25:50 +02:00
|
|
|
|
|
|
|
Enable Xdebug for the port set in ``xdebug.ini``:
|
|
|
|
|
2018-07-03 15:47:58 +02:00
|
|
|
.. include:: ../_includes/figures/xdebug/phpstorm-settings.rst
|
2018-04-11 08:25:50 +02:00
|
|
|
|
|
|
|
Create a new PHP server and set a path mapping. This tutorial assumes your local Devilbox projects
|
|
|
|
to be in ``./data/www`` of the Devilbox git directory:
|
|
|
|
|
2018-07-03 15:47:58 +02:00
|
|
|
.. include:: ../_includes/figures/xdebug/phpstorm-path-mapping.rst
|
2018-04-11 08:25:50 +02:00
|
|
|
|
|
|
|
Set DBGp proxy settings:
|
|
|
|
|
2018-07-03 15:47:58 +02:00
|
|
|
.. include:: ../_includes/figures/xdebug/phpstorm-dbgp-proxy.rst
|
2018-04-11 08:25:50 +02:00
|
|
|
|
2018-04-08 12:20:00 +02:00
|
|
|
|
|
|
|
MacOS (Docker for Mac)
|
|
|
|
^^^^^^^^^^^^^^^^^^^^^^
|
2018-04-10 09:32:06 +02:00
|
|
|
.. todo:: Help needed. Please provide your config.
|
2018-04-08 12:20:00 +02:00
|
|
|
|
|
|
|
MacOS (Docker Toolbox)
|
|
|
|
^^^^^^^^^^^^^^^^^^^^^^
|
2018-04-10 09:32:06 +02:00
|
|
|
.. todo:: Help needed. Please provide your config.
|
2018-04-08 12:20:00 +02:00
|
|
|
|
|
|
|
Windows (Docker for Windows)
|
|
|
|
^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
2018-04-10 09:32:06 +02:00
|
|
|
.. todo:: Help needed. Please provide your config.
|
2018-04-08 12:20:00 +02:00
|
|
|
|
|
|
|
Windows (Docker Toolbox)
|
|
|
|
^^^^^^^^^^^^^^^^^^^^^^^^
|
2018-04-10 09:32:06 +02:00
|
|
|
.. todo:: Help needed. Please provide your config.
|
2018-04-08 12:20:00 +02:00
|
|
|
|
|
|
|
|
|
|
|
Sublime Text 3
|
|
|
|
--------------
|
|
|
|
|
|
|
|
1. Install `Xdebug Client <https://github.com/martomo/SublimeTextXdebug>`_ via the Sublime Package Control.
|
2018-04-10 09:32:06 +02:00
|
|
|
2. Configure ``Xdebug.sublime-settings`` (Tools -> Xdebug -> Settings - User)
|
2018-04-08 12:20:00 +02:00
|
|
|
|
2018-04-10 09:32:06 +02:00
|
|
|
Linux
|
|
|
|
^^^^^^
|
2018-04-08 12:20:00 +02:00
|
|
|
.. code-block:: json
|
2018-06-03 19:16:22 +02:00
|
|
|
:caption: Xdebug-sublime-settings
|
|
|
|
:emphasize-lines: 3,6
|
2018-04-08 12:20:00 +02:00
|
|
|
|
2018-06-03 19:16:22 +02:00
|
|
|
{
|
|
|
|
"path_mapping": {
|
|
|
|
"/shared/httpd" : "/home/cytopia/repo/devilbox/data/www"
|
|
|
|
},
|
|
|
|
"url": "",
|
|
|
|
"ide_key": "PHPSTORM",
|
|
|
|
"host": "0.0.0.0",
|
|
|
|
"port": 9000
|
|
|
|
}
|
2018-04-08 12:20:00 +02:00
|
|
|
|
|
|
|
|
2018-04-10 09:32:06 +02:00
|
|
|
MacOS (Docker for Mac)
|
|
|
|
^^^^^^^^^^^^^^^^^^^^^^
|
|
|
|
.. todo:: Help needed. Please provide your config.
|
|
|
|
|
|
|
|
MacOS (Docker Toolbox)
|
|
|
|
^^^^^^^^^^^^^^^^^^^^^^
|
|
|
|
.. todo:: Help needed. Please provide your config.
|
|
|
|
|
|
|
|
Windows (Docker for Windows)
|
|
|
|
^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
|
|
|
.. todo:: Help needed. Please provide your config.
|
|
|
|
|
|
|
|
Windows (Docker Toolbox)
|
|
|
|
^^^^^^^^^^^^^^^^^^^^^^^^
|
|
|
|
.. todo:: Help needed. Please provide your config.
|
2018-04-08 12:20:00 +02:00
|
|
|
|
|
|
|
|
2018-04-10 09:32:06 +02:00
|
|
|
Visual Studio Code
|
|
|
|
------------------
|
2018-04-08 12:20:00 +02:00
|
|
|
|
2018-04-10 09:32:06 +02:00
|
|
|
1. Install `vscode-php-debug <https://github.com/felixfbecker/vscode-php-debug>`_
|
|
|
|
2. Configure ``launch.json``
|
2018-04-08 12:20:00 +02:00
|
|
|
|
2018-04-10 09:32:06 +02:00
|
|
|
Linux
|
|
|
|
^^^^^^
|
|
|
|
.. code-block:: json
|
2018-06-03 19:16:22 +02:00
|
|
|
:caption: launch.json
|
|
|
|
:emphasize-lines: 9,10
|
|
|
|
|
|
|
|
{
|
|
|
|
"version": "0.2.0",
|
|
|
|
"configurations": [
|
|
|
|
{
|
|
|
|
"name": "Listen for Xbebug",
|
|
|
|
"type": "php",
|
|
|
|
"request": "launch",
|
|
|
|
"port": 9000,
|
|
|
|
"serverSourceRoot": "/shared/httpd",
|
|
|
|
"localSourceRoot": "/home/cytopia/repo/devilbox/data/www"
|
|
|
|
}, {
|
|
|
|
"name": "Launch currently open script",
|
|
|
|
"type": "php",
|
|
|
|
"request": "launch",
|
|
|
|
"program": "${file}",
|
|
|
|
"cwd": "${fileDirname}",
|
|
|
|
"port": 9000
|
|
|
|
}
|
|
|
|
]
|
|
|
|
}
|
2018-04-08 12:20:00 +02:00
|
|
|
|
|
|
|
|
|
|
|
MacOS (Docker for Mac)
|
|
|
|
^^^^^^^^^^^^^^^^^^^^^^
|
2018-04-10 09:32:06 +02:00
|
|
|
.. todo:: Help needed. Please provide your config.
|
2018-04-08 12:20:00 +02:00
|
|
|
|
|
|
|
MacOS (Docker Toolbox)
|
|
|
|
^^^^^^^^^^^^^^^^^^^^^^
|
2018-04-10 09:32:06 +02:00
|
|
|
.. todo:: Help needed. Please provide your config.
|
2018-04-08 12:20:00 +02:00
|
|
|
|
|
|
|
Windows (Docker for Windows)
|
|
|
|
^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
2018-04-10 09:32:06 +02:00
|
|
|
.. todo:: Help needed. Please provide your config.
|
2018-04-08 12:20:00 +02:00
|
|
|
|
|
|
|
Windows (Docker Toolbox)
|
|
|
|
^^^^^^^^^^^^^^^^^^^^^^^^
|
2018-04-10 09:32:06 +02:00
|
|
|
.. todo:: Help needed. Please provide your config.
|
2018-04-08 12:20:00 +02:00
|
|
|
|
|
|
|
|
|
|
|
..
|
|
|
|
MacOS videos
|
|
|
|
https://serversforhackers.com/c/getting-xdebug-working
|
|
|
|
https://serversforhackers.com/c/auto-config
|
|
|
|
|
|
|
|
https://www.arroyolabs.com/2016/10/docker-xdebug/
|
|
|
|
|
|
|
|
https://medium.com/@yuliakostrikova/configure-remote-debugging-with-xdebug-for-php-docker-container-on-macos-8edbc01dc373
|
|
|
|
|
|
|
|
https://github.com/petronetto/php7-alpine
|
|
|
|
|
|
|
|
#old
|
|
|
|
docker.for.mac.localhost
|
|
|
|
#new
|
|
|
|
docker.for.mac.host.internal
|
|
|
|
|
|
|
|
docker.for.win.localhost
|