Configurar Visual Studio Code + Laradock + xDebug

Viusal Studio Code

Visual Studio Code é um editor de código redefinido e otimizado para criar e depurar aplicações modernas para a web. O Visual Studio Code é gratuito e está disponível para a tua plataforma favorita — Linux, macOS e Windows.

Laradock

Laradock é um ambiente de desenvolvimento PHP completo para Docker.

xDebug

xDebug é uma extensão do PHP para auxiliar na depuração e desenvolvimento.

Editar o ficheiro .env na pasta do Laradock

  • nano .env
  • Procurar WORKSPACE_INSTALL_XDEBUG e substituir o valor por true
  • Procurar PHP_FPM_INSTALL_XDEBUG e substituir o valor por true

Editar os ficheiros de configuração do xDebug

  • nano workspace/xdebug.ini
  • nano php-fpm/xdebug.ini
  • Substituir o conteúdo de ambos os ficheiros por:
xdebug.remote_host=host.docker.internal
xdebug.remote_connect_back=1
xdebug.remote_port=9000
xdebug.idekey=VSCODE
xdebug.remote_autostart=1
xdebug.remote_enable=1
xdebug.cli_color=1
xdebug.profiler_enable=1
xdebug.profiler_output_dir="~/xdebug/vscode/tmp/profiling"
xdebug.remote_handler=dbgp
xdebug.remote_mode=req
xdebug.var_display_max_children=-1
xdebug.var_display_max_data=-1
xdebug.var_display_max_depth=-1

Rebuild e reiniciar os containers workspace e php-fpm

  • docker-compose build workspace php-fpm
  • docker-compose up -d workspace php-fpm
  • docker-compose restart workspace php-fpm

Activar o xDebug no Visual Studio Code

  • No menu do Visual Studio Code, clicar Run e de seguida Add Configuration
  • Adicionar a configuração seguinte:
{
"name": "Listen for XDebug",
"type": "php",
"request": "launch",
"port": 9000,
"log": true,
"pathMappings": {
"/var/www": "${workspaceRoot}",
},
"ignore": [
"**/vendor/**/*.php"
]
}

Start/Stop xDebug

Ao instalar o xDebug, este fica ativo para ser executado no startup por padrão.

--

--

Full Stack Web Developer

Love podcasts or audiobooks? Learn on the go with our new app.

Get the Medium app

A button that says 'Download on the App Store', and if clicked it will lead you to the iOS App store
A button that says 'Get it on, Google Play', and if clicked it will lead you to the Google Play store