VSC怎么配置PHP的Xdebug_远程调试设置步骤【详解】
技术百科
蓮花仙者
发布时间:2026-01-01
浏览: 次 需先确认Xdebug版本为3.x并启用调试模式,再配置php.ini中zend_extension、xdebug.mode=debug、xdebug.client_host、xdebug.client_port=9003及xdebug.log,最后在VS Code中安装PHP Debug插件并正确设置launch.json的port和pathMappings。
确认 Xdebug 版本和 PHP 运行模式
VS Code 本身不运行 PHP,它依赖本地或远程的 PHP 环境 + Xdebug 扩展。先在终端执行 php -v 和 php -m | grep xdebug,确认 Xdebug 已加载。注意:Xdebug 3 和 Xdebug 2 的配置项完全不同,且 Xdebug 3 默认不兼容旧版 IDE 配置。若输出中含 Xdebug v3.x,后续所有 zend_extension 路径、xdebug.mode、xdebug.client_host 等必须按 v3 规范写;若仍是 v2,需停用并升级,因为 VS Code 的 PHP Debug 插件已不再维护对 Xdebug 2 的兼容支持。
修改 php.ini 启用远程调试(Xdebug 3)
找到正在使用的 php.ini(用 php --ini 查),在末尾添加以下内容(根据实际环境调整):
zend_extension=xdebug.so xdebug.mode=debug xdebug.start_with_request=yes xdebug.client_host=127.0.0.1 xdebug.client_port=9003 xdebug.log=/tmp/xdebug.log
关键点:
-
xdebug.mode=debug是 Xdebug 3 的必需开关,仅设zend_extension不会启动调试 - 本地开发时
xdebug.client_host通常为127.0.0.1;若 PHP 运行在 Docker 容器内且 VS Code 在宿主机,这里要填宿主机网关(如host.docker.internal或172.17.0.1) -
端口必须与 VS Code 中
launch.json的port一致,默认是9003(Xdebug 2 是9000) -
xdebug.log强烈建议开启,出问题时直接看日志比猜配置快得多
VS Code
安装插件并配置 launch.json
安装官方扩展:PHP Debug(作者 Felix Becker)。然后在项目根目录创建 .vscode/launch.json,内容如下:
{
"version": "0.2.0",
"configurations": [
{
"name": "Listen for Xdebug",
"type": "php",
"request": "launch",
"port": 9003,
"pathMappings": {
"/var/www/html/": "${workspaceFolder}/"
}
}
]
}
说明:
-
port必须与php.ini中的xdebug.client_port完全一致 -
pathMappings是远程调试的核心映射:左边是服务器上 PHP 文件的绝对路径(如 Docker 内/var/www/html/index.php),右边是本地对应文件夹(${workspaceFolder}即 VS Code 当前打开的文件夹) - 如果 PHP 在远程服务器(非 Docker),且你用 SFTP 同步代码,
pathMappings左边应填远程服务器上的真实路径,如/home/user/project/
启动调试并验证断点是否生效
启动调试前务必:
- 重启 Web 服务或 PHP-FPM(
sudo systemctl restart php-fpm或sudo service apache2 restart)使php.ini生效 - 在 VS Code 中点击左侧调试图标 → 选择
Listen for Xdebug→ 点击绿色 ▶️ 启动监听 - 在 PHP 文件中打一个断点(如
index.php第一行),然后在浏览器访问该 URL(如http://localhost/index.php)
如果断点未命中,立刻检查 /tmp/xdebug.log:常见错误包括连接被拒绝(端口不匹配)、路径映射失败(Could not map file)、Xdebug 尝试连错 IP(如连了 127.0.0.1 但实际需连宿主机 IP)。Docker 用户最容易卡在 client_host 配置上——容器里 127.0.0.1 指自己,不是宿主机。
# 重启
# 最容易
# 先在
# 浏览器
# app
# 旧版
# 端口
# internal
# http
# js
# json
# docker
# html
# 仍是
# var
# vs code
# map
# php
# 卡在
# for
# apache
# ide
# 你用
# vscode
# 器上
# 强烈建议
# 不兼容
相关栏目:
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
AI推广<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
SEO优化<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
技术百科<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
谷歌推广<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
百度推广<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
网络营销<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
案例网站<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
精选文章<?muma echo $count; ?>
】
相关推荐
- php增删改查需要哪些扩展_开启mysqli或pd
- 本地php环境打开php文件直接下载_浏览器解析p
- php报错怎么查看_定位PHP致命错误与警告的方法
- c++怎么使用类型萃取type_traits_c+
- PHP cURL GET请求:正确设置请求头与身份
- Win10怎么关闭自动更新错误重启 Win10策略
- 手机php文件怎么变成mp4_安卓苹果打开php转
- LINUX怎么设置系统语言_LINUX修改中文环境
- Win10如何更改用户账户控制_Windows10
- Win11怎么更改输入法顺序_Win11调整语言首
- Windows10如何重置此电脑_Windows1
- 如何使用Golang实现Web表单数据绑定_自动映
- 如何在Golang中配置代码格式化工具_使用gof
- MAC怎么设置程序窗口永远最前_MAC窗口置顶插件
- Win11怎么设置屏保时间_调整Win11屏幕保护
- ACF 教程:正确更新嵌套在多层 Group 字段
- Windows10蓝屏代码DPC_WATCHDOG
- Win11怎样安装钉钉客户端_Win11安装钉钉教
- PHP怎么接收前端传的时间戳_处理时间戳参数转换技
- Python正则表达式实战_模式匹配说明【教程】
- C#怎么使用委托和事件 C# delegate与e
- 如何从 Go 的 map[string]inter
- Python函数接口稳定性_版本演进解析【指导】
- Win11怎么设置DNS服务器_Windows11
- C++如何使用Qt创建第一个GUI窗口?(入门教程
- Win11怎么关闭专注助手 Win11关闭免打扰模
- Python数据抓取合法性_合规说明【指导】
- php删除数据怎么加限制_带where条件删除避免
- Win11怎么关闭搜索历史 Win11清除搜索框最
- 如何使用Golang管理模块版本_Golanggo
- Win11怎么退出高对比度模式_Win11取消反色
- Windows电脑如何进入安全模式?(多种按键方法
- Win11怎么调整屏幕亮度_Windows 11调
- Win10怎样卸载自带Edge_Win10卸载Ed
- Win11怎么设置指纹解锁 Win11笔记本录入指
- Win11蓝牙开关不见了怎么办_Win11蓝牙驱动
- Win11 explorer.exe频繁崩溃_修复
- Mac怎么安装软件_Mac安装dmg与pkg文件的
- php485读数据时阻塞怎么办_php485非阻塞
- Win11怎么查看显卡温度 Win11任务管理器查
- php订单日志权限怎么设_php订单日志文件权限设
- Python文件管理规范_工程实践说明【指导】
- MySQL 中使用 IF 和 CASE 实现查询字
- Windows蓝屏错误0x00000018怎么处理
- Win11鼠标灵敏度怎么调 Win11鼠标指针移动
- 如何使用Golang实现文件加密_Golang c
- php在Linux怎么部署_LNMP环境搭建PHP
- php与c语言在嵌入式中有何区别_对比两者在硬件控
- Win11怎么查看wifi信号强度_检测Windo
- 如何用列表一次性对 DataFrame 的指定列应

安装插件并配置 launch.json
QQ客服