php xdebug远程调试配置(含cli模式)

找了很久php的xdebug扩展远程调试教程,大都已经过时,现在记录下php配置xdebug远程调试的过程。

适用php版本: php 7 ~ 8

适用安装xdebug3 版本

目录

1. 安装xdebug

关于windows下的安装

关于linux下的安装

2. 配置phpstorm远程调试

 1. 全局监听(监听xdebug端口的所有请求,不推荐)

 2. 根据配置文件的debug(推荐)

3. 命令行cli调试

1. 安装xdebug

关于windows下的安装

官网下载:Xdebug: Downloads

找到需要的版本下载

解压下载好的压缩包,提取dll文件,放到php的ext扩展目录下 ,

dll文件例如: php_xdebug-3.1.0beta2-7.4-vc15-nts-x86_64.dll

Ps:有可能需要php.ini 中ext指定扩展目录,一般不用设置

 

如果你不知道下载什么版本,那就去 Xdebug: Support — Tailored Installation Instructions

在命令行输入 php -i 或者打印出 phpinfo() ,复制里面全部的文本内容到链接中输入框,官方会提供下载指引。

安装xdebug后,接下来就是修改php.ini配置文件了

新版xdebug3的配置已经变了,旧的教程已经不合适了,会在php_error.log报错的

Xdebug3需要在php.ini中添加以下配置

Ps:记得改成自己需要的配置

    ;指定xdebug扩展位置
    zend_extension=xdebug-3.1.0beta2-7.4-vc15-nts-x86_64.dll
     
    ;配置xdebug
    [xdebug]
    ;配置xdebug主机地址
    xdebug.client_host = localhost
    ;监听端口
    xdebug.client_port = 9103
    ;idekey
    xdebug.idekey = PHPSTORM
    ;调试模式建议设置成debug可以打断点调试,默认是default
    xdebug.mode = debug,trace

以上就是最少的xdebug配置了,想知道更多xdebug配置介绍可以去官网看看 Xdebug: Documentation » All settings ,里面都有介绍什么配置有什么功能。

最后可以在命令行输入php -m 查看是否安装xdebug成功

关于linux下的安装

官网首页都有Linux安装示例了,自己看 Xdebug: Documentation » Installation

2. 配置phpstorm远程调试

示例phpstorm版本2022.2.5,因为phpstorm不同版本功能与布局不太一样,所以使用方式也因版本不同。

全局debug配置

点击蓝色的validate链接可以验证当前配置是否正确。

配置主机映射

设置主机映射,用于在浏览器访问时,phpstorm能够根据url链接路径映射到实际的运行文件,可设置多个,不同的项目使用不同的设置。根据实际情况设置,我这里设置一个就行了。用的是thinkphp6,指向的是项目根目录(也可以是public目录,自己根据需要填写),主要是匹配你的web服务程序的真实目录与运行目录,比如在docker内的nginx的运行目录是\data,但文件真实存在别的地方。

PS:如果IDE能自动识别也就不用勾选 use path mappings 了,不过我看大部分情况都是识别不了

 1. 全局监听(监听xdebug端口的所有请求,不推荐)

开启电话图标代表监听所有对php的请求,不区分请求服务的域名,当有请求到php时就会触发xdebug拦截,请求越多弹出的debug窗口越多,缺点是难以判断是哪个请求产生的debug。

 2. 根据配置文件的debug(推荐)

在右上角的 Run/Debug Configurations 配置处创建调试配置,也适用与命令行cli调试。

 

下图是完整配置,创建并选择调试配置文件。

配置好后就可以打上断点,点击小甲虫调试图标就可以开始调试了。根据配置文件的debug有一个好处就是可以区分是哪个项目触发的,当同时有多个请求会自动阻塞排队,一个一个执行debug。

接下来可以在浏览器使用以下两种方式调试:

方法一:

浏览器url 后面加上XDEBUG_SESSION_START=1 首先 ,这个 XDEBUG_SESSION_START 是必须的,但是他的值是可以随便填写的。

    如:https://xxxx.com?XDEBUG_SESSION_START=1

参考文档:  Xdebug: Documentation » All settings

 

方法二:

在浏览器安装 Xdebug helper 调试插件,至于怎么安装,请自行百度。

这个工具会自动帮你设置,只不过他是在 cookie 里面设置,依赖cookie。

安装完成后,需要先配置,右键扩展栏的虫子图标,选择选项。

大功告成,现在可以开始调试了,使用浏览器访问url会自动停在断点处,有时候调试自动断开 nginx 返回 504这是因为你没有调整 PHP 和 FPM 以及 Nginx 的最大执行时间,修改到一个较大的值即可。

参考文档:

https://segmentfault.com/a/1190000019775071

PhpStorm配置Xdebug调试 - 艾薇-Ivy - 博客园

3. 命令行cli调试

如果你想对命令行cli运行的脚本进行调试,可以这样配置

创建与选中php scripti脚本调试配置后点击小虫子即可开始调试,可以在脚本中打断点了!!

注意:xdebug只能调试传统php开发模式,不能调试Swoole与Workerman

等什么时候有空再发docker下的xdebug/swoole远程调试教程,如果会变通的话上述配置是可以修改为远程调试服务器的教程的,等有空再发详细教程吧