商城首页欢迎来到中国正版软件门户

您的位置:首页 >如何在Ubuntu用phpstorm调试代码

如何在Ubuntu用phpstorm调试代码

  发布于2026-05-01 阅读(0)

扫一扫,手机访问

在 Ubuntu 上使用 PhpStorm 调试 PHP 的完整步骤

如何在Ubuntu用phpstorm调试代码

想在 Ubuntu 上优雅地调试 PHP 代码?PhpStorm 配合 Xdebug 无疑是专业开发者的首选。但配置过程里,版本匹配、端口冲突这些“小坑”总是让人头疼。别担心,下面这份从环境准备到问题排查的完整指南,能帮你把路铺平。

一 环境准备

调试的基础,在于一个干净、一致的环境。首先,确保你的系统已经安装了 PHP 和 Web 服务(Apache 或 Nginx + PHP-FPM)。这里有个关键点:务必确认命令行(CLI)和 FPM 服务使用的 PHP 版本是完全一致的,无论是 7.4 还是 8.0 到 8.3 的任一版本。

接下来,安装与 PHP 版本匹配的 Xdebug 扩展。对于 Ubuntu 或 Debian 系用户,最直接的方式就是通过包管理器:运行 sudo apt-get install php-xdebug 即可。安装完成后,别忘了用 php -vphp -m | grep xdebug 命令验证一下扩展是否成功加载。

二 配置 Xdebug 3(Ubuntu 20.04+ 与 PHP 8 推荐)

Xdebug 升级到第 3 版后,配置项变得更清晰,但第一步得找对配置文件。你需要根据 PHP 的运行方式,找到正确的 ini 文件位置(请将下文中的 {php_version} 替换为你的实际版本号):

  • CLI:/etc/php/{php_version}/cli/php.ini
  • FPM:/etc/php/{php_version}/fpm/php.ini
  • Apache:/etc/php/{php_version}/apache2/php.ini

找到文件后,在对应 ini 文件的末尾添加或修改为以下 Xdebug 3 的常用配置:

[XDebug]
zend_extension=xdebug.so
xdebug.mode=debug
xdebug.client_host=127.0.0.1
xdebug.client_port=9003
xdebug.start_with_request=yes
xdebug.idekey=PHPSTORM

这里需要说明一下:client_port 默认是 9003。如果你的 9003 端口已被其他服务(比如 php-fpm)占用,可以将其改为 9000、9100 等未被占用的端口。

配置保存后,必须重启相关服务才能生效:

  • 对于 FPM:sudo systemctl restart php{php_version}-fpm
  • 对于 Web 服务器sudo systemctl restart apache2sudo systemctl restart nginx

三 配置 PhpStorm

服务端搞定后,就该配置 IDE 了。打开 PhpStorm,首先设置 PHP 解释器:进入 File → Settings → Languages & Frameworks → PHP → CLI Interpreter,选择或添加系统路径 /usr/bin/php

接着,配置服务器与调试端口,这是建立连接的关键:

  • Servers:在 Languages & Frameworks → PHP → Servers 中点击 + 号,填写 Name、Host(如 localhost)、Port(如 80 或 443),并将 Debugger 选为 Xdebug。对于本地开发,通常不需要进行路径映射。
  • Debug:进入 Languages & Frameworks → PHP → Debug,将 Debug port 设置为与上一步 xdebug.client_port 完全一致的值(默认是 9003)。

最后,创建一个运行配置:点击 Run → Edit Configurations → + → PHP Web Page,选择刚才创建的 Server,并配置好 Start URL(例如 /index.php)。

四 开始调试

一切就绪,可以开始享受调试的乐趣了。首先,在你关心的代码行号左侧单击,设置一个断点。然后,在 PhpStorm 的工具栏上找到那个“电话听筒”图标并点击,开始监听调试连接(等价于执行 Run → Start Listening for PHP Debug Connections)。

如何触发调试呢?有两种主流方式:

  • 浏览器直接访问:在目标页面的 URL 后追加参数 ?XDEBUG_SESSION_START=PHPSTORM,例如访问 http://localhost:8080/index.php?XDEBUG_SESSION_START=PHPSTORM
  • 使用浏览器扩展:安装如 Xdebug Helper 这类扩展,将 IDE Key 设置为 PHPSTORM 后,访问页面时一键激活。

当代码执行到你设置的断点时,PhpStorm 会自动弹出调试窗口。这时,你就可以使用 F7(单步进入)F8(单步跳过)Shift+F8(跳出) 等快捷键控制执行流程,并实时查看变量值与调用栈信息了。

五 常见问题与排查

即使步骤清晰,实战中也可能遇到一些小麻烦。以下是几个典型问题的排查思路:

  • 端口被占用:如果 9003 端口冲突,将 xdebug.client_port 与 PhpStorm 中的 Debug port 同步修改为 9000、9100 等其他未被占用的端口即可。
  • 监听未触发:请确认 PhpStorm 已点击“电话听筒”图标开始监听,并且访问的 URL 包含了 XDEBUG_SESSION_START=PHPSTORM 参数,或浏览器扩展已正确启用。
  • 配置未生效:仔细核对修改的是否是 FPM 或 Apache 实际生效的 php.ini 文件,并确保已重启对应服务。可以通过 phpinfo() 页面或运行 php -i | grep xdebug 命令来检查 Xdebug 配置是否已成功加载。
  • 虚拟机/Vagrant/WSL 场景:在这些环境下,需要在 IDE 的 Deployment → Mappings 中配置好本地与虚拟环境的目录映射,并确保网络端口转发设置正确,这是成功建立调试连接的前提。
本文转载于:https://www.yisu.com/ask/15522571.html 如有侵犯,请联系zhengruancom@outlook.com删除。
免责声明:正软商城发布此文仅为传递信息,不代表正软商城认同其观点或证实其描述。

热门关注