如何在Ubuntu用phpstorm调试代码
在 Ubuntu 上使用 PhpStorm 调试 PHP 的完整步骤

免费影视、动漫、音乐、游戏、小说资源长期稳定更新! 👉 点此立即查看 👈
想在 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 -v 或 php -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 apache2或sudo 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 中配置好本地与虚拟环境的目录映射,并确保网络端口转发设置正确,这是成功建立调试连接的前提。
游乐网为非赢利性网站,所展示的游戏/软件/文章内容均来自于互联网或第三方用户上传分享,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系youleyoucom@outlook.com。
同类文章
Linux上Node.js的日志管理技巧有哪些
在Linux上高效管理Node js应用程序日志的十个核心技巧 要让一个Node js应用在Linux服务器上稳定运行,日志管理是绕不开的一环。处理得当,它是排查问题的利器;放任不管,它可能瞬间拖垮磁盘。下面这张图概括了我们将要探讨的核心技巧,接下来,我们就逐一拆解,看看如何让日志系统既健壮又易于维
Linux中JS文件权限设置方法
在Linux中设置Ja vaScript文件权限 在Linux环境下,想让Ja vaScript文件被Web服务器正常解析和执行,正确设置文件权限是关键一步。这通常意味着文件需要具备可读和可执行权限。实现这个目标,主要依靠chmod这个强大的命令。下面,我们就来详细拆解一下具体的操作流程。 操作步骤
Linux环境下JS代码调试技巧有哪些
在Linux环境下调试Ja vaScript代码,可以采用以下几种技巧 在Linux上捣鼓Ja vaScript,调试这事儿说难不难,说简单也得讲究方法。下面这几个技巧,算是开发圈里公认的高效路径,咱们挨个捋一遍。 1 使用Node js内置调试器 Node js自带的调试器,算是开箱即用的首选。
Linux环境下ThinkPHP安全认证实现
在Linux环境下,使用ThinkPHP框架实现安全认证 在Linux服务器上为ThinkPHP应用构建一套可靠的安全认证体系,是保障业务逻辑和数据安全的基础。下面,我们就来一步步拆解这个实现过程。 1 安装ThinkPHP框架 万事开头难,但第一步其实很标准。首先,确保你的Linux环境已经准备
Linux中ThinkPHP错误处理机制
Linux环境下ThinkPHP错误处理机制全面解析 在Linux服务器上部署和运行ThinkPHP应用时,其强大的错误处理机制是保障应用稳定性的基石。该机制的核心在于对PHP原生错误、异常以及致命错误进行统一的接管与处理。这一切主要由think Error::register()方法初始化完成,它
- 日榜
- 周榜
- 月榜
1
2
3
4
5
6
7
8
9
10
1
2
3
4
5
6
7
8
9
10
相关攻略
2015-03-10 11:25
2015-03-10 11:05
2021-08-04 13:30
2015-03-10 11:22
2015-03-10 12:39
2022-05-16 18:57
2025-05-23 13:43
2025-05-23 14:01
热门教程
- 游戏攻略
- 安卓教程
- 苹果教程
- 电脑教程
热门话题

