Я пытаюсь использовать 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
Не могу подключить Xdebug к VSCode ⇐ Php
Кемеровские программисты php общаются здесь
1764022521
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?op=get&search=0x14aa40ec0831756756d7f66c4f4ea0aae5267a6c' | 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/nodesource-repo.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).
Подробнее здесь: [url]https://stackoverflow.com/questions/79805121/cant-connect-xdebug-to-vscode[/url]
Ответить
1 сообщение
• Страница 1 из 1
Перейти
- Кемерово-IT
- ↳ Javascript
- ↳ C#
- ↳ JAVA
- ↳ Elasticsearch aggregation
- ↳ Python
- ↳ Php
- ↳ Android
- ↳ Html
- ↳ Jquery
- ↳ C++
- ↳ IOS
- ↳ CSS
- ↳ Excel
- ↳ Linux
- ↳ Apache
- ↳ MySql
- Детский мир
- Для души
- ↳ Музыкальные инструменты даром
- ↳ Печатная продукция даром
- Внешняя красота и здоровье
- ↳ Одежда и обувь для взрослых даром
- ↳ Товары для здоровья
- ↳ Физкультура и спорт
- Техника - даром!
- ↳ Автомобилистам
- ↳ Компьютерная техника
- ↳ Плиты: газовые и электрические
- ↳ Холодильники
- ↳ Стиральные машины
- ↳ Телевизоры
- ↳ Телефоны, смартфоны, плашеты
- ↳ Швейные машинки
- ↳ Прочая электроника и техника
- ↳ Фототехника
- Ремонт и интерьер
- ↳ Стройматериалы, инструмент
- ↳ Мебель и предметы интерьера даром
- ↳ Cантехника
- Другие темы
- ↳ Разное даром
- ↳ Давай меняться!
- ↳ Отдам\возьму за копеечку
- ↳ Работа и подработка в Кемерове
- ↳ Давай с тобой поговорим...
Мобильная версия