Как подключить Xdebug к VSCodePhp

Кемеровские программисты php общаются здесь
Ответить
Anonymous
 Как подключить Xdebug к VSCode

Сообщение Anonymous »

Я пытаюсь использовать Xdebug в VSCode. Кажется, Xdebug запущен, но я не могу заставить VSCode использовать установленные мной точки останова. В файле журнала (см. ниже) показано какое-то несоответствие между файлами, в которых я установил точку останова (в данном случае IndexController.php).
Файл IndexController загружается в Laravel, php --ini показывает мой .ini-файл и настройки, которые я настроил. До сих пор я пробовал все комбинации путей, которые только мог придумать, но, похоже, это не проблема, потому что другие пути будут выдавать исключение «файл не найден» в журнале Xdebug. Насколько я вижу, журнал launch.json не содержит никакой соответствующей информации.
Моя среда выглядит следующим образом:

Виртуальная машина -> WSL -> контейнеры Laravel/mysql/mail/etc
VSCode работает на виртуальной машине, но я использую расширение WSL в VSCode для доступа к своему дистрибутиву WSL.
Я установил расширение PHP Debug для VSCode внутри контейнера WSL.
Xdebug на данный момент устанавливается через dockerfile версии 3.4.5.
Соответствующий фрагмент из docker-compose:
services:
laravel.test:
build:
context: ./docker/8.4
dockerfile: Dockerfile
args:
WWWGROUP: '${WWWGROUP}'
image: sail-8.4/app
extra_hosts:
- 'host.docker.internal:host-gateway'
ports:
- '${APP_PORT:-80}:80'
- '${VITE_PORT:-5173}:${VITE_PORT:-5173}'
environment:
WWWUSER: '${WWWUSER}'
LARAVEL_SAIL: 1
XDEBUG_MODE: '${SAIL_XDEBUG_MODE:-debug}'
XDEBUG_CONFIG: '${SAIL_XDEBUG_CONFIG:-client_host=host.docker.internal}'
volumes:
- '.:/var/www/html'
networks:
- sail
depends_on:
- mysql
- redis
- mailpit
- minio

Файл Docker:
FROM ubuntu:22.04

LABEL maintainer="Taylor Otwell"

ARG WWWGROUP
ARG NODE_VERSION=20
ARG POSTGRES_VERSION=15

WORKDIR /var/www/html

ENV DEBIAN_FRONTEND noninteractive
ENV TZ=UTC
ENV SUPERVISOR_PHP_COMMAND="/usr/bin/php -d variables_order=EGPCS /var/www/html/artisan serve --host=0.0.0.0 --port=80"

RUN ln -snf /usr/share/zoneinfo/$TZ /etc/localtime && echo $TZ > /etc/timezone

RUN apt-get update \
&& mkdir -p /etc/apt/keyrings \
&& apt-get install -y gnupg gosu curl ca-certificates zip unzip git supervisor sqlite3 libcap2-bin libpng-dev python2 dnsutils librsvg2-bin fswatch ffmpeg \
&& curl -sS 'https://keyserver.ubuntu.com/pks/lookup ... aae5267a6c' | gpg --dearmor | tee /etc/apt/keyrings/ppa_ondrej_php.gpg > /dev/null \
&& echo "deb [signed-by=/etc/apt/keyrings/ppa_ondrej_php.gpg] https://ppa.launchpadcontent.net/ondrej/php/ubuntu jammy main" > /etc/apt/sources.list.d/ppa_ondrej_php.list \
&& apt-get update \
&& apt-get install -y php8.4-cli php8.4-dev \
php8.4-pgsql php8.4-sqlite3 php8.4-gd \
php8.4-curl \
php8.4-imap php8.4-mysql php8.4-mbstring \
php8.4-xml php8.4-zip php8.4-bcmath php8.4-soap \
php8.4-intl php8.4-readline \
php8.4-ldap \
php8.4-msgpack php8.4-igbinary php8.4-redis php8.4-swoole \
php8.4-memcached php8.4-pcov php8.4-imagick php8.4-xdebug \
&& curl -sLS https://getcomposer.org/installer | php -- --install-dir=/usr/bin/ --filename=composer \
# && curl -fsSL https://deb.nodesource.com/gpgkey/nodes ... po.gpg.key | gpg --dearmor -o /etc/apt/keyrings/nodesource.gpg \
# && echo "deb [signed-by=/etc/apt/keyrings/nodesource.gpg] https://deb.nodesource.com/node_$NODE_VERSION.x nodistro main" > /etc/apt/sources.list.d/nodesource.list \
&& apt-get update \
&& curl -fsSL https://raw.githubusercontent.com/tj/n/master/bin/n | bash -s install lts \
&& npm install -g pnpm \
&& npm install -g bun \
&& curl -sS https://dl.yarnpkg.com/debian/pubkey.gpg | gpg --dearmor | tee /etc/apt/keyrings/yarn.gpg >/dev/null \
&& echo "deb [signed-by=/etc/apt/keyrings/yarn.gpg] https://dl.yarnpkg.com/debian/ stable main" > /etc/apt/sources.list.d/yarn.list \
&& curl -sS https://www.postgresql.org/media/keys/ACCC4CF8.asc | gpg --dearmor | tee /etc/apt/keyrings/pgdg.gpg >/dev/null \
&& echo "deb [signed-by=/etc/apt/keyrings/pgdg.gpg] http://apt.postgresql.org/pub/repos/apt jammy-pgdg main" > /etc/apt/sources.list.d/pgdg.list \
&& apt-get update \
&& apt-get install -y yarn \
&& apt-get install -y mysql-client \
&& apt-get install -y postgresql-client-$POSTGRES_VERSION \
&& apt-get -y autoremove \
&& apt-get clean \
&& rm -rf /var/lib/apt/lists/* /tmp/* /var/tmp/*

RUN setcap "cap_net_bind_service=+ep" /usr/bin/php8.4

RUN groupadd --force -g $WWWGROUP sail
RUN useradd -ms /bin/bash --no-user-group -g $WWWGROUP -u 1337 sail

COPY start-container /usr/local/bin/start-container
COPY supervisord.conf /etc/supervisor/conf.d/supervisord.conf
COPY php.ini /etc/php/8.4/cli/conf.d/99-sail.ini
RUN chmod +x /usr/local/bin/start-container

EXPOSE 8000

ENTRYPOINT ["start-container"]

Файл php.ini, который копируется в 99-sail.ini внутри контейнера Laravel:
[PHP]
post_max_size = 100M
upload_max_filesize = 100M
variables_order = EGPCS
pcov.directory = .

[opcache]
opcache.enable_cli=1

[xdebug]
zend_extension=/usr/lib/php/20240924/xdebug.so
xdebug.mode=debug
xdebug.start_with_request=yes
xdebug.client_port=9003
xdebug.client_host=host.docker.internal
xdebug.log=/tmp/xdebug.log
xdebug.log_level=10
xdebug.idekey=VSCODE

{
"configurations": [
{
"name": "Listen for Xdebug",
"type": "php",
"request": "launch",
"port": [
9003
],
"pathMappings": {
"/var/www/html": "{workspaceFolder}"
},
"log": true
}
]
}

Журналы xdebug:
[16] [Step Debug] DEBUG: Breakpoint 160002 (type: exception).
[16] [Step Debug] DEBUG: D: Breakpoint 160002 (type: exception) is already resolved.
[16] [Step Debug] DEBUG: Breakpoint 160003 (type: exception).
[16] [Step Debug] DEBUG: D: Breakpoint 160003 (type: exception) is already resolved.
[16] [Step Debug] DEBUG: Breakpoint 160004 (type: exception).
[16] [Step Debug] DEBUG: D: Breakpoint 160004 (type: exception) is already resolved.
[16] [Step Debug] DEBUG: Breakpoint 160005 (type: exception).
[16] [Step Debug] DEBUG: D: Breakpoint 160005 (type: exception) is already resolved.
[16] [Step Debug] DEBUG: Breakpoint 160001 (type: line).
[16] [Step Debug] DEBUG: R: File name (/var/www/html/vendor/laravel/framework/src/Illuminate/Queue/Console/FailedTableCommand.php) does not match breakpoint to resolve (/home/max/git/Project/app/Http/Controllers/Dashboard/IndexController.php).


Подробнее здесь: https://stackoverflow.com/questions/798 ... -to-vscode
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «Php»