phpstorm在Ubuntu中的调试技巧有哪些
Ubuntu下使用 PhpStorm 的高效调试技巧

免费影视、动漫、音乐、游戏、小说资源长期稳定更新! 👉 点此立即查看 👈
一 基础环境快速配置
想让PhpStorm在Ubuntu上火力全开,第一步就是把调试环境搭建利索。这事儿不难,跟着下面几步走,十分钟内就能搞定。
首先,安装Xdebug扩展。注意,一定要选择与你当前PHP版本匹配的。比如你用的是PHP 8.1,那么命令就是:sudo apt-get install php8.1-xdebug。安装完成后,别忘了去PhpStorm里确认一下调试端口:打开 File > Settings > PHP > Debug,看看端口是不是默认的9003。
接下来是配置的核心环节——修改php.ini。配置文件的位置通常在 /etc/php/{版本号}/{sapi}/php.ini,或者在同目录的 mods-a vailable/xdebug.ini 里。你需要添加或确保以下几行配置:
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
这里有个关键细节:如果你的项目同时通过命令行(CLI)和网页服务(如FPM/Apache)运行,那么这两套环境可能有各自独立的php.ini文件,需要分别进行配置。修改保存后,务必重启对应的服务:sudo systemctl restart php8.1-fpm 或 apache2。
最后,回到PhpStorm完成收尾工作。在 Languages & Frameworks > PHP > Servers 中,新增一个服务器,Host填localhost,端口根据你的情况填80或443,Debugger选择Xdebug。然后,在 Run > Edit Configurations 里新建一个“PHP Web Page”,选择刚创建的服务器,并填上项目的入口页面路径。
至此,基础配置就完成了。在代码行左侧点击设置一个断点,然后点击工具栏上的“小虫子”图标启动调试监听,再用浏览器访问你的页面,就能看到程序稳稳地停在了断点处。
二 本地与远程调试的实用技巧
环境配好了,怎么用得更顺手?掌握下面这几个技巧,能让你在各种场景下游刃有余。
最省心的方式是“一键监听”。点击PhpStorm工具栏上的电话图标,或者选择 Run > Start Listening for PHP Debug Connections。开启后,PhpStorm就会进入等待状态,一旦有符合条件的请求进来,它会自动捕获并中断,无需每次都手动启动调试。
对于网页调试,给浏览器装个“开关”会更方便。安装 Xdebug Helper 这个浏览器插件(Chrome和Firefox都有),在插件选项里将IDE key设置为PHPSTORM。之后,在需要调试的页面上点击插件图标并启用调试,页面刷新时就会自动连接到PhpStorm的断点。
如果没有插件,手动触发也行。方法有两种:一是在访问的URL后面直接加上参数 ?XDEBUG_SESSION_START=PHPSTORM;二是在请求的Cookie中带上 XDEBUG_SESSION=PHPSTORM。这两种方式都能强制让请求进入调试会话。
命令行脚本怎么调试?其实原理相通。在执行脚本前,先设置一个环境变量:export XDEBUG_SESSION=PHPSTORM,然后再运行 php your_script.php。同时,确保PhpStorm已经对那个脚本文件设置了断点并开启了监听。
如今后端开发离不开API调试,用Postman这类工具也能轻松对接。只需在新建的请求中,添加一个名为 XDEBUG_SESSION、值为 PHPSTORM 的Cookie,发送请求后,程序就会在PhpStorm的断点处暂停。
三 远程服务器与容器场景
开发环境越来越复杂,代码可能跑在虚拟机、Docker容器甚至远端的云服务器上。别担心,Xdebug同样能覆盖。
如果你的服务运行在本机,但代码放在虚拟机或Docker容器里,关键是要让容器内的Xdebug能找到“回家”的路。需要将容器内Xdebug配置中的 xdebug.client_host 设置为宿主机在容器网络内的IP地址(例如 192.168.x.x,Docker Desktop用户可以用 host.docker.internal 这个特殊域名)。同时,PhpStorm里Servers配置中的Host,要填写为访问服务时用的服务器域名或IP。
更直接的情况是,代码和PHP解释器都在远程服务器上。这时,需要把远程服务器上Xdebug的 client_host 设置成你本地开发机的公网或内网IP地址,并确保服务器防火墙和安全组规则放行了9003端口。本地PhpStorm则保持监听状态,就能接收到来自远端的调试请求了。
这里还有一个至关重要的步骤:路径映射。因为远程服务器的代码路径(如 /var/www/project)和本地项目路径完全不同,必须告诉PhpStorm如何对应。在 Run/Debug Configurations > PHP Web Page > Server 的配置中,设置好服务器上的绝对路径与本地项目路径的映射关系。这一步是保证断点能准确命中的关键所在。
四 调试效率提升与常见问题
工具用熟了,接下来就该追求效率了。掌握调试器的操作技巧和常见问题的排错方法,能节省大量时间。
先说几个最常用的调试控制快捷键,记住它们能让操作行云流水:
- Step Over (F8):执行当前行,如果遇到函数调用,不会进入函数内部,直接得到结果。
- Step Into (F7):进入当前行所调用的函数内部,一步步跟踪。
- Force Step Into:强制进入,有时能跳过一些构造方法或袋里,直达你想看的函数核心。
- Step Out (Shift+F8):快速执行完当前函数剩余的所有代码,并返回到调用它的地方。
- Run to Cursor:让程序一直运行,直到执行到你光标所在的那一行。
除了普通断点,善用“条件断点”能避免无效中断。在断点上右键,可以设置一个条件表达式(例如 $user->id == 100),只有条件为真时才会中断。你也可以设置“日志断点”,命中时不中断程序,只是输出一条信息,非常适合用来追踪变量变化。
调试时,Variables 面板会展示当前作用域的所有变量,Watches 面板则可以持续监视某个复杂表达式的值。而 Frames(调用堆栈)面板堪称“时光机”,能清晰展示函数是如何一层层被调用到当前位置的,点击任意一层即可跳转到对应的上下文。
最后,盘点几个新手常踩的坑以及解决办法:
- 端口被占用:检查9003端口是否已被其他进程(比如老版本PHP-FPM默认使用9000端口,有时会造成冲突)占用。必要时,可以修改Xdebug配置和PhpStorm设置中的端口号,只要两者保持一致即可。
- 断点死活不命中:请按顺序排查:1) 确认
xdebug.mode=debug;2) 核对client_host和client_port配置无误;3) 确保PhpStorm的调试监听已开启;4) 检查Servers配置中的Host和端口映射是否正确。 - 只有命令行调试生效,网页访问无效:这通常是修改了CLI的php.ini,却忘了同步修改并重启FPM或Apache所用的php.ini和服务导致的。
- 远程服务器连接失败:首先确认
client_host填的是调试客户端(你的本机)的真实可达IP。如果用的是云服务器,务必在安全组或防火墙规则中放行9003端口的入站流量。
把这些技巧和注意事项摸透,在Ubuntu上用PhpStorm进行调试,就能从磕磕绊绊变得畅通无阻了。
游乐网为非赢利性网站,所展示的游戏/软件/文章内容均来自于互联网或第三方用户上传分享,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系youleyoucom@outlook.com。
同类文章
Sublime写前端代码卡顿怎么办?优化Sublime运行速度的几个设置
Sublime写前端代码卡顿怎么办?优化Sublime运行速度的几个设置 有没有遇到过这种情况?明明只是敲几行代码,Sublime Text却突然变得一卡一卡的,光标移动都带着延迟。别急着怀疑电脑性能,问题很可能出在编辑器本身的设置上。尤其是前端项目,动辄成千上万的依赖文件,对编辑器来说是个不小的负
VSCode怎么把选中的大段代码片段一键提取为一个新的函数或方法
VSCode Extract Function:选中代码前必须确认三件事 想把一段代码变成独立的函数?VSCode的Extract Function功能确实能一键搞定。但先别急着操作,这个功能可不会猜你的心思,它只认“语法上合法的选中区域”。很多时候操作失败,并不是功能坏了,而是你选中的代码块本身就
VSCode远程开发断连_解决SSH连接超时与自动重连
根本原因是服务器端sshd空闲超时或防火墙 NAT丢弃连接,需两端配合:服务端启用ClientAliveInterval 60和ClientAliveCountMax 3并重启sshd,客户端检查~ ssh config避免冲突,同时清理VSCode残留进程并更新扩展。 SSH连接被服务器主动断开
VSCode项目资源管理器排序_按类型或修改时间排列文件
VSCode资源管理器默认按什么排序? 当你打开VSCode的资源管理器,看着里面一堆文件,有没有好奇过它们的排列顺序?默认情况下,VSCode采用的是最“老实”的规则:按文件名的字母顺序排列,并且不区分大小写。这意味着,index js之所以排在README md前面,仅仅是因为字母“i”在字母表
Sublime怎么配置Kotlin环境?Sublime编写Kotlin代码高亮设置
Sublime Text 不能直接运行 Kotlin,但可通过安装 Kotlin 插件实现语法高亮,并配置构建系统调用 kotlinc 和 ja va 编译运行;前提是 JDK 与 Kotlin 编译器已正确安装并加入 PATH,且构建系统中 selector 必须为 source kotlin、-
- 日榜
- 周榜
- 月榜
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
热门教程
- 游戏攻略
- 安卓教程
- 苹果教程
- 电脑教程
热门话题

