配置本地 docker 中运行的 PHP xdebug 环境

在最近的调试过程中一直无法正确断点,最后发现是 xdebug 的配置问题,记录一下。

在 Docker 中配置 PHP 和 Xdebug 调试环境,通常从以下几个步骤开始:

1. 创建一个包含 PHP 和 Xdebug 的 Dockerfile

首先创建一个 Dockerfile,包含 PHP 和 Xdebug 的安装步骤。以下是一个简单的示例:

Dockerfile 复制代码
FROM php:8.2-apache

RUN pecl install xdebug && docker-php-ext-enable xdebug

COPY ./php.ini /usr/local/etc/php/conf.d/
COPY ./000-default.conf /etc/apache2/sites-available/

此示例使用了官方 PHP 8.2 容器,并安装了 Xdebug 扩展。

2. 配置 php.ini 文件

在项目中创建一个 php.ini 文件,包含以下 Xdebug 配置:

ini 复制代码
xdebug.mode=debug
xdebug.start_with_request=yes
xdebug.client_host=host.docker.internal
xdebug.client_port=9003
xdebug.idekey=PHPSTORM
  • xdebug.mode=debug 启用调试模式。
  • xdebug.start_with_request=yes 指示 Xdebug 对每个请求启动调试。
  • xdebug.client_host=host.docker.internal 特殊 DNS 名称,用于从容器内访问主机。Docker 容器通常使用 host.docker.internal 这个别名来引用主机系统。对于 Docker Desktop for Mac 和 Windows 工作。
  • xdebug.client_port=9003 是 Xdebug 3 中的默认监听端口。在 PhpStorm 中也使用相同端口。
  • xdebug.idekey=PHPSTORM 设置 IDE key。这对应于您在 PhpStorm 中配置的 key。

3. 创建并配置虚拟主机(可选)

如果需要,创建一个 000-default.conf 文件,其中包含您的 Apache 虚拟主机配置:

xml 复制代码
<VirtualHost *:80>
    DocumentRoot /var/www/html/public
    <Directory /var/www/html/public>
        AllowOverride All
        Require all granted
    </Directory>
</VirtualHost>

4. 构建并运行 Docker 容器

在 Dockerfile 所在的目录中运行以下命令:

bash 复制代码
docker build -t my-php-xdebug .
docker run -d -p 80:80 --name my-php-xdebug-instance -v $(pwd):/var/www/html my-php-xdebug-container

此命令将构建一个名为 my-php-xdebug 的 Docker 镜像,并使用名为 my-php-xdebug-instance 的实例运行它。将 80:80 映射到主机,以便通过 http://localhost 访问。

5. 配置 PhpStorm

配置 PhpStorm,并确保等待计算机接收 Xdebug 连接(点击小电话图标,启用 PHP debug 监听)。

对项目进行映射配置,确保在 PHPStrom 中可以断点到正确的位置。

6. 设置 PHP_IDE_CONFIG 环境变量

在运行容器时使用 --env 标志设置 PHP_IDE_CONFIG 环境变量:

bash 复制代码
docker run -d --env PHP_IDE_CONFIG="serverName=myServer" my-php-xdebug-instance

将 "myServer" 替换为在第 5 步的 PhpStorm 设置的服务器名称。这是比较重要的一步,如果不设置这个环境变量,那么在 PhpStorm 中断点将不会生效。

相关推荐
保持低旋律节奏4 小时前
linux——进程状态
android·linux·php
计算机学姐5 小时前
基于php的摄影网站系统
开发语言·vue.js·后端·mysql·php·phpstorm
计算机学姐5 小时前
基于php的旅游景点预约门票管理系统
开发语言·后端·mysql·php·phpstorm
百***07456 小时前
GPT-5.2国内稳定接入实战指南:中转调用全链路方案(Python适配)
python·gpt·php
小阿宁的猫猫8 小时前
sqlmap的使用
sql·网络安全·php
roman_日积跬步-终至千里8 小时前
【Starrocks】StarRocks 排错:`Invalid method name: ‘heartbeat‘`(BE 心跳端口/协议错误)
服务器·网络·php
Maybe I Simple8 小时前
PHP常用方法封装
php
slongzhang_9 小时前
PHP图片处理|画布入门
开发语言·php
知码者9 小时前
对于Thinkphp5可能遇到的保存问题
服务器·php·apache·小程序开发·跨平台小程序
郑州光合科技余经理10 小时前
实战分享:如何构建东南亚高并发跑腿配送系统
java·开发语言·javascript·spring cloud·uni-app·c#·php