当前位置: 首页
编程语言
如何在Ubuntu用phpstorm调试代码

如何在Ubuntu用phpstorm调试代码

热心网友 时间:2026-05-04
转载

在 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

游乐网为非赢利性网站,所展示的游戏/软件/文章内容均来自于互联网或第三方用户上传分享,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系youleyoucom@outlook.com。

同类文章
更多
Linux上Node.js的日志管理技巧有哪些

Linux上Node.js的日志管理技巧有哪些

在Linux上高效管理Node js应用程序日志的十个核心技巧 要让一个Node js应用在Linux服务器上稳定运行,日志管理是绕不开的一环。处理得当,它是排查问题的利器;放任不管,它可能瞬间拖垮磁盘。下面这张图概括了我们将要探讨的核心技巧,接下来,我们就逐一拆解,看看如何让日志系统既健壮又易于维

时间:2026-05-04 21:19
Linux中JS文件权限设置方法

Linux中JS文件权限设置方法

在Linux中设置Ja vaScript文件权限 在Linux环境下,想让Ja vaScript文件被Web服务器正常解析和执行,正确设置文件权限是关键一步。这通常意味着文件需要具备可读和可执行权限。实现这个目标,主要依靠chmod这个强大的命令。下面,我们就来详细拆解一下具体的操作流程。 操作步骤

时间:2026-05-04 21:18
Linux环境下JS代码调试技巧有哪些

Linux环境下JS代码调试技巧有哪些

在Linux环境下调试Ja vaScript代码,可以采用以下几种技巧 在Linux上捣鼓Ja vaScript,调试这事儿说难不难,说简单也得讲究方法。下面这几个技巧,算是开发圈里公认的高效路径,咱们挨个捋一遍。 1 使用Node js内置调试器 Node js自带的调试器,算是开箱即用的首选。

时间:2026-05-04 21:18
Linux环境下ThinkPHP安全认证实现

Linux环境下ThinkPHP安全认证实现

在Linux环境下,使用ThinkPHP框架实现安全认证 在Linux服务器上为ThinkPHP应用构建一套可靠的安全认证体系,是保障业务逻辑和数据安全的基础。下面,我们就来一步步拆解这个实现过程。 1 安装ThinkPHP框架 万事开头难,但第一步其实很标准。首先,确保你的Linux环境已经准备

时间:2026-05-04 21:18
Linux中ThinkPHP错误处理机制

Linux中ThinkPHP错误处理机制

Linux环境下ThinkPHP错误处理机制全面解析 在Linux服务器上部署和运行ThinkPHP应用时,其强大的错误处理机制是保障应用稳定性的基石。该机制的核心在于对PHP原生错误、异常以及致命错误进行统一的接管与处理。这一切主要由think Error::register()方法初始化完成,它

时间:2026-05-04 21:18
热门专题
更多
刀塔传奇破解版无限钻石下载大全 刀塔传奇破解版无限钻石下载大全
洛克王国正式正版手游下载安装大全 洛克王国正式正版手游下载安装大全
思美人手游下载专区 思美人手游下载专区
好玩的阿拉德之怒游戏下载合集 好玩的阿拉德之怒游戏下载合集
不思议迷宫手游下载合集 不思议迷宫手游下载合集
百宝袋汉化组游戏最新合集 百宝袋汉化组游戏最新合集
jsk游戏合集30款游戏大全 jsk游戏合集30款游戏大全
宾果消消消原版下载大全 宾果消消消原版下载大全
  • 日榜
  • 周榜
  • 月榜
热门教程
更多
  • 游戏攻略
  • 安卓教程
  • 苹果教程
  • 电脑教程