2018-07-23 21:25:48 +00:00
|
|
|
:orphan:
|
|
|
|
|
|
|
|
.. include:: /_includes/all.rst
|
|
|
|
|
|
|
|
.. _configure_php_xdebug_win:
|
|
|
|
|
|
|
|
************************************
|
|
|
|
Configure Xdebug: Docker for Windows
|
|
|
|
************************************
|
|
|
|
|
|
|
|
Docker for Windows requires a well known IP address in order to connect to the host operating system.
|
|
|
|
This can be achieved with two different approaches described below.
|
|
|
|
|
|
|
|
**Table of Contents**
|
|
|
|
|
|
|
|
.. contents:: :local:
|
|
|
|
|
|
|
|
|
|
|
|
Prerequisites
|
|
|
|
=============
|
|
|
|
|
|
|
|
Ensure you know how to customize ``php.ini`` values for the Devilbox and Xdebug is enabled.
|
|
|
|
|
|
|
|
.. seealso::
|
|
|
|
* :ref:`php_ini`
|
|
|
|
* :ref:`configure_php_xdebug_options`
|
|
|
|
|
|
|
|
|
|
|
|
Configure php.ini: CNAME alias
|
|
|
|
==============================
|
|
|
|
|
|
|
|
**Option 1:** This option is the easiest to setup, but was also very fragile on many Docker versions.
|
|
|
|
|
|
|
|
Docker for Windows received many default CNAMEs throughout its versions. The most recent and active
|
|
|
|
one is ``host.docker.internal``. Use this CNAME as the remote address for Xdebug to connect to your
|
|
|
|
IDE/editor on your host os.
|
|
|
|
|
|
|
|
.. seealso::
|
|
|
|
CNAME for :ref:`connect_to_host_os_docker_for_win`
|
|
|
|
In case ``host.docker.internal`` is not resolvable, read on here for alternative CNAME's
|
|
|
|
on Docker for Windows
|
|
|
|
|
|
|
|
.. important::
|
|
|
|
|
|
|
|
Before you try this approach, verify that the PHP Docker container is actually able to resolve
|
|
|
|
``host.docker.internal``:
|
|
|
|
|
|
|
|
.. code-block:: bash
|
|
|
|
|
|
|
|
C:\> cd path\to\devilbox
|
|
|
|
C:\> shell.bat
|
|
|
|
php> ping host.docker.internal
|
|
|
|
|
|
|
|
In case it is not resolvable, stick to the host alias address approach.
|
|
|
|
|
|
|
|
The following example show how to configure PHP Xdebug for PHP 5.6:
|
|
|
|
|
|
|
|
**1. Create xdebug.ini**
|
|
|
|
|
|
|
|
1. Navigate to the Devilbox directory
|
|
|
|
2. Navigate to ``cfg\php-ini-5.6\`` directory
|
|
|
|
3. Create a new file named ``xdebug.ini``
|
|
|
|
|
|
|
|
.. important::
|
|
|
|
Pay attention that windows is not adding ``.txt`` as a file extension.
|
|
|
|
|
|
|
|
**2. Paste the following content into xdebug.ini**
|
|
|
|
|
|
|
|
.. code-block:: ini
|
|
|
|
:caption: xdebug.ini
|
2018-08-04 00:20:47 +00:00
|
|
|
:emphasize-lines: 7-8,12
|
2018-07-23 21:25:48 +00:00
|
|
|
|
|
|
|
# Defaults
|
2018-08-04 00:20:47 +00:00
|
|
|
xdebug.default_enable=1
|
2018-07-23 21:25:48 +00:00
|
|
|
xdebug.remote_enable=1
|
|
|
|
xdebug.remote_port=9000
|
|
|
|
|
|
|
|
# The Windows way (CNAME)
|
|
|
|
xdebug.remote_connect_back=0
|
|
|
|
xdebug.remote_host=host.docker.internal
|
|
|
|
|
|
|
|
# idekey value is specific to each editor
|
|
|
|
# Verify IDE/editor documentation
|
|
|
|
xdebug.idekey=PHPSTORM
|
|
|
|
|
|
|
|
# Optional: Set to true to auto-start xdebug
|
|
|
|
xdebug.remote_autostart=false
|
|
|
|
|
|
|
|
**3. Configure your IDE/editor**
|
|
|
|
|
|
|
|
.. seealso::
|
|
|
|
* :ref:`configure_php_xdebug_editor_atom`
|
|
|
|
* :ref:`configure_php_xdebug_editor_phpstorm`
|
|
|
|
* :ref:`configure_php_xdebug_editor_sublime3`
|
|
|
|
* :ref:`configure_php_xdebug_editor_vscode`
|
|
|
|
|
|
|
|
.. important::
|
|
|
|
Depending on your IDE/editor, you might have to adjust ``xdebug.idekey`` in the above
|
|
|
|
configured ``xdebug.ini``.
|
|
|
|
|
|
|
|
**4. Restart the Devilbox**
|
|
|
|
|
|
|
|
Restarting the Devilbox is important in order for it to read the new PHP settings.
|
|
|
|
|
|
|
|
|
|
|
|
Configure php.ini: Get IP manually
|
|
|
|
==================================
|
|
|
|
|
|
|
|
**Option 2:** This is the most general option that should work with any Docker version on Windows.
|
|
|
|
it does however require a small manual step.
|
|
|
|
|
|
|
|
The following example show how to configure PHP Xdebug for PHP 5.6:
|
|
|
|
|
|
|
|
**1. Gather IP address for Xdebug**
|
|
|
|
|
|
|
|
On Windows you will have to manually gather the IP address and add it to ``xdebug.remote_host``.
|
|
|
|
|
|
|
|
1. Open command line
|
|
|
|
2. Enter ``ipconfig``
|
|
|
|
3. Look for the IP4 address in ``DockerNAT`` (e.g.: ``192.168.246.1``)
|
|
|
|
|
|
|
|
.. seealso:: :ref:`howto_open_terminal_on_win`
|
|
|
|
|
|
|
|
.. important::
|
|
|
|
``192.168.246.1`` is meant as an example and will eventually differ on your system.
|
|
|
|
Ensure you substitute it with the correct IP address.
|
|
|
|
|
|
|
|
**2. Create xdebug.ini**
|
|
|
|
|
|
|
|
1. Navigate to the Devilbox directory
|
|
|
|
2. Navigate to ``cfg\php-ini-5.6\`` directory
|
|
|
|
3. Create a new file named ``xdebug.ini``
|
|
|
|
|
|
|
|
.. important::
|
|
|
|
Pay attention that windows is not adding ``.txt`` as a file extension.
|
|
|
|
|
|
|
|
**3. Paste the following content into xdebug.ini**
|
|
|
|
|
|
|
|
.. code-block:: ini
|
|
|
|
:caption: xdebug.ini
|
2018-08-04 00:20:47 +00:00
|
|
|
:emphasize-lines: 7-8,12
|
2018-07-23 21:25:48 +00:00
|
|
|
|
|
|
|
# Defaults
|
2018-08-04 00:20:47 +00:00
|
|
|
xdebug.default_enable=1
|
2018-07-23 21:25:48 +00:00
|
|
|
xdebug.remote_enable=1
|
|
|
|
xdebug.remote_port=9000
|
|
|
|
|
|
|
|
# The Windows way (IP address)
|
|
|
|
xdebug.remote_connect_back=0
|
|
|
|
xdebug.remote_host=192.168.246.1
|
|
|
|
|
|
|
|
# idekey value is specific to each editor
|
|
|
|
# Verify IDE/editor documentation
|
|
|
|
xdebug.idekey=PHPSTORM
|
|
|
|
|
|
|
|
# Optional: Set to true to auto-start xdebug
|
|
|
|
xdebug.remote_autostart=false
|
|
|
|
|
|
|
|
.. important::
|
|
|
|
``192.168.246.1`` is meant as an example and will eventually differ on your system.
|
|
|
|
Ensure you substitute it with the correct IP address.
|
|
|
|
|
|
|
|
**4. Configure your IDE/editor**
|
|
|
|
|
|
|
|
.. seealso::
|
|
|
|
* :ref:`configure_php_xdebug_editor_atom`
|
|
|
|
* :ref:`configure_php_xdebug_editor_phpstorm`
|
|
|
|
* :ref:`configure_php_xdebug_editor_sublime3`
|
|
|
|
* :ref:`configure_php_xdebug_editor_vscode`
|
|
|
|
|
|
|
|
.. important::
|
|
|
|
Depending on your IDE/editor, you might have to adjust ``xdebug.idekey`` in the above
|
|
|
|
configured ``xdebug.ini``.
|
|
|
|
|
|
|
|
**5. Restart the Devilbox**
|
|
|
|
|
|
|
|
Restarting the Devilbox is important in order for it to read the new PHP settings.
|