PhpStorm 远程调试 WordPress 一例
PhpStorm 调试概述
-
PhpStorm 调试 PHP 可以分为本机调试和远程调试,为了更好的模拟测试、生产环境,建议做远程调试。一般的开发环境为 Windows,而生产环境一般为 Linux 环境。
-
PhpStorm 调试支持 Xdebug 或 Zend Debugger ,PhpStorm 推荐使用 Xdebug。具体文档请参见 官方调试文档。
本篇所述环境为:
- CentOS 8.4
- Nginx 1.20.0
- php-fpm 8.0.8
- Zend Engine v4.0.8
- Xdebug v3.0.4
data:image/s3,"s3://crabby-images/673ac/673ac1e858d924d5f1be133a2fc2e0de15414bc9" alt="system-info"
- PhpStorm IDE 调试原理
data:image/s3,"s3://crabby-images/acd02/acd023a833d8340c30cb9bfe2810f4da1a386d2a" alt="debug-principle"
如图:右边机器(IP=10.0.1.2)是布署了Nginx/php的服务端(下文简称php服务端),左侧机器(IP=10.0.1.42)是布署了IDE(比如Phpstorm)的IDE端(下文简称IDE端)。调试中基本通信过程说明:
-
打开浏览器,访问web页面,nginx通过fastcgi网关接口加载PHP脚本运行 (对应图上第一个朝向右的箭头)。
-
然后php解释器(当然必须已装好Xdebug扩展),向IDE端的9000端口( 本文下面用的都是9001,原因是我本机9000端口被其它程序占用)发起基于DBGP协议的调试请求。
-
IDE端收到DBGP协议请求后,就可以开始单步调试了。
-
调试完成后,服务端php解释器执行完毕,向浏览器返回response。
安装服务器环境
请参见以下文档安装概述中环境:
-
在 CentOS 8 / RHEL 8 上使用 DNF 及 DNF module 安装 Nginx 1.20 及 PHP8.0
-
安装完 Nginx 及 PHP 后就可以安装 WordPress 了
安装 Xdebug
正常安装 REMI 仓库后,就可以 dnf search 到Xdebug了
data:image/s3,"s3://crabby-images/3bb5e/3bb5e2686b9508d6524f24bbba862c16ecfbc0c4" alt="xdebug-info"
到此,服务器端就配置完成了。
浏览器调试插件安装
根据 Xdebug 或 Zend Debugger 文档描述,在调试过程中,需要设置 GET/POST 或者 COOKIE 参数,这些参数可以手动设置,但是使用浏览器扩展很方便。一下是扩展插件及支持的浏览器:
chrome | Firefox | Internet Explorer | safari | Opera | |
---|---|---|---|---|---|
Xdebug | Xdebug Helper | Xdebug Helper or Xdebug-ext | PhpStorm bookmarklets generator | Xdebug Toggle | PhpStorm bookmarklets generator |
Zend Debugger | zDebug or Zend Debugger Toolbar | Zend Debugger Toolbar | |||
Z-Ray for Zend Server version 7 or later. PhpStorm bookmarklets generator otherwise | |||||
Z-Ray for Zend Server version 7 or later. PhpStorm bookmarklets generator otherwise |
由于国内安装 Chrome 插件比较困难,所以建议使用 Firefox 调试,安装 Firefox 的 Xdebug Helper 插件:
- 打开 Firefox 附件组件设置:
data:image/s3,"s3://crabby-images/ba98e/ba98e5b73a1d7593fc6f03e74f466d0c3a136a89" alt="open-firefox-setting"
- 搜索 Xdebug Helper 插件
data:image/s3,"s3://crabby-images/f984b/f984b2000ee474cb67a37e43a8f43a1ae38eba0a" alt="search-xdebug-helper"
- 查找并安装 Xdebug Helper:
data:image/s3,"s3://crabby-images/f0e49/f0e494886428a23bbf5b95b2493e0cbda5d0dc89" alt="xdebug-helper-serach"
- 安装完毕后进行调试:
data:image/s3,"s3://crabby-images/21c10/21c103d3d7485051ce12f5d4d65a1be4d62ef950" alt="Firefox-debug-helper"
PhpStorm 远程调试
创建工程
- 创建已存在的工程
data:image/s3,"s3://crabby-images/2ec68/2ec68c5d644e4ccdfcf576f49b2c01adbaf1f55c" alt="new-project"
- 由于我们使用的是 虚拟机搭建环境,可以很容易的使用 FTP 协议传输文件,所以 选择:
data:image/s3,"s3://crabby-images/2a0ae/2a0ae07fdf2b848bf153271aee92c18936a373ca" alt="ftp-info"
- 设置工程名称
data:image/s3,"s3://crabby-images/fb180/fb180469f6288378e5081383713a56bf9e85cadc" alt="project-name"
- 添加远程服务器信息
data:image/s3,"s3://crabby-images/75668/75668ea3c9f1fe60c41bc5835f79ea815caaa251" alt="project-server-info"
data:image/s3,"s3://crabby-images/79ca9/79ca98f008dd891ed42d5cc63f478b604161b7bf" alt="ssh-info"
- 选择远程路径
如果前几步配置好的话,这里就可以直接 Next了
data:image/s3,"s3://crabby-images/eba6f/eba6faec53705b5cd1fad5a959ef65d9945aa254" alt="project-remote-path"
- 指定 Web 路径:
同上,也可以直接 Next:
data:image/s3,"s3://crabby-images/2b25a/2b25aa4471ad3c6f95b8f0c8fedb0e86072dc1f1" alt="project-specify-web-path"
- 然后,会出现一个 failed:
data:image/s3,"s3://crabby-images/c9ee6/c9ee68feccb5c35ba29a0d71a1746e4e3e2af359" alt="create-new-project-failed"
- 奇迹
按照 1-5 步骤 重新来一边,你会发现奇迹。
data:image/s3,"s3://crabby-images/e15e2/e15e2725b98ab3b18be379a1a45e9383340066a2" alt="project-succeed"
PhpStorm 设置
- PhpStorm 设置:
file -> settings 打开配置页面:
data:image/s3,"s3://crabby-images/41964/419642d5eac1696af9c62b4a0f191053563fb418" alt="phpstrom-settings"
- 首先配置一个 CLI Interpreter:
data:image/s3,"s3://crabby-images/cd53d/cd53db593cc816310fd4324cfcaac7ac6e2352d1" alt="php-cli-setting"
data:image/s3,"s3://crabby-images/13a97/13a974d8266ea235192abc51c92f6ecb5ed07373" alt="ssh-setting"
data:image/s3,"s3://crabby-images/908c3/908c3d061368d57177fb3d041299f0b9bbd3a257" alt="remote-php-interpreter"
data:image/s3,"s3://crabby-images/2a6e4/2a6e4ab9c49994edbccfd922d59047da747f9ca0" alt="cli-interpreters"
- 配置一个 server
data:image/s3,"s3://crabby-images/69b2a/69b2abc78a196e32cf0c4d2c58de88eb1b30d918" alt="setting-php-server"
- 添加一个 运行配置:
data:image/s3,"s3://crabby-images/354e0/354e0ec5d7bdabbba560cf3768a88f918c9c8144" alt="add-configuration"
data:image/s3,"s3://crabby-images/5a480/5a48050c0841e5ce946ff0118de205167f930af1" alt="add-web-page"
校验错误:
data:image/s3,"s3://crabby-images/5a428/5a42873a98f056c23cd0679ddd0ddc5065c7fb5f" alt="validate-failed"
在服务器段 vim 打开 php.ini 配置文件,按照上图提示加入参数:
data:image/s3,"s3://crabby-images/710ed/710eddd41503abacce6f0ea2749ab17e1bff2f5a" alt="php-ini-setting"
systemctl restartphp80-php-fpm
重启php-fpm 再次校验成功:
data:image/s3,"s3://crabby-images/ab954/ab954c7f1a3e436f12455dceaea68e50338181c9" alt="validate-successful"
配置后为:
data:image/s3,"s3://crabby-images/22df2/22df201eea481ab0e8a7c149ba54e88c5fdd41b7" alt="configurations-web-php"
- 运行调试
浏览器打开或者点击
data:image/s3,"s3://crabby-images/7a703/7a703f1f53b390f6d3f7e462b89261a7bd377174" alt="exp-click"
出现:
data:image/s3,"s3://crabby-images/c0864/c08648cb79bbda2da920474d5b26b34ee6e6a107" alt="Incoming-conection-from-xdebug"
点解 accept 接受调试
- 成功捕获到调试信息
data:image/s3,"s3://crabby-images/6db4e/6db4ee9791bde78c4365a85da0904dbe8fd57dbc" alt="phpstrom-debug"