博客原文连接php
在使用php调试代码的时候,我一般都是使用简单暴力的echo
之类的输出调试。这种调试方法的效率与我的能力正相关,你加一个echo
多数是为了验证本身的一个推测,那么你对代码越熟悉,你推测的就会越准确,bug解决的就越快,相反则每每如无头苍蝇般,东一头西一头,不知所谓地输出一些无心义的调试信息,效率奇低。此时单步调试工具便成了救命稻草,有了它,你能够查看代码执行过程当中全部变量的值,心如明镜,解个bug还不手到擒来。对于php,经常使用的就是xdebug,我这里就简单讲下IDEA
里面如何使用xdebug
进行代码调试。浏览器
咱们先把xdebug安装好,因为这里是远程调试,因此xdebug要安装到php运行的服务器上,若是php是在本地环境中,那就直接安装到本地,官方安装文档在这里,我这里简单讲一下Centos 6.6
+PHP 5.4
的安装方法。服务器
下载而且编译xdebug。
下载连接-xdebug-2.2.7.tgz架构
wget http://xdebug.org/files/xdebug-2.2.7.tgz
tar zxvf xdebug-2.2.7.tgz
cd xdebug-2.2.7
phpize&make&make installapp
修改php配置框架
在php.ini中增长以下一行:
zend_extension = /usr/local/lib/php/extensions/no-debug-non-zts-20100525/xdebug.soeclipse
安装完毕!ide
在实际使用前,咱们来简单了解xdebug远程调试的原理,这样当xdebug不听话的时候,咱们也知道从哪里收拾它。详细文档参见此处。工具
xdebug远程调试分为两部分:调试客户端和xdebug服务端。前者就是运行咱们代码调试器的地方,我这里是IDEA
,后者是xdebug
运行的地方。当咱们尝试使用xdebug进行调试时,客户端会监听一个端口,等待xdebug来链接,一旦链接成功,双方就开始通讯,进行代码调试。优化
图一,源图
图一动态展现了xdebug运行的原理,左边是调试客户端,好比IDEA
、eclipse
之类的IDE,右边是xdebug
,运行按照以下步骤进行:
IDE
监听一个调试端口,默认是9000
,能够自行配置。
用户访问右边php环境的server,咱们这里使用浏览器访问,通常IDE
会自动帮咱们在正常的url后面增长XDEBUG_SESSION_START=name
的参数。这个参数是用来通知xdebug
主动链接IDE
的9000
端口进行调试的,没有这个参数,xdebug不会去主动链接IDE
,调试也就不会触发。
xdebug
主动去链接IDE
的9000
端口, 链接成功后,调试开始。
细心的同窗可能会问,xdebug
是如何知道IDE
监听9000
端口的呢?好问题,答案就在配置文件里面。xdebug
有两个配置:remote_host
和remote_port
,分别表明IDE
的ip地址和监听端口。因而可知,IDE
和xdebug
必须协商好监听端口。
另外一个问题又来了,端口好办,可是若是个人ip会变化,那我换一个ip,岂不是要修改下xdebug.remote_host
配置吗?好麻烦!!!不知道ip不要紧,xdebug
能够本身知道,只要设置xdebug.remote_connect_back
为1就能够了,其运行原理见图二,实现很简单,xdebug
能够从http请求的头部获取ip地址,以后就用该ip地址做为remote_host
来链接。
图二,源图
到这里,相信你们已经基本了解xdebug
的原理了,本着好记性不如烂笔头
的准则,这里把个人配置列一下,方便查阅。
[xdebug] zend_extension = /usr/local/lib/php/extensions/no-debug-non-zts-20100525/xdebug.so xdebug.remote_connect_back=1 xdebug.remote_enable=1 xdebug.remote_port=9444 xdebug.remote_autostart=1 xdebug.profiler_enable=1 xdebug.profiler_output_dir="/home/logs/xdebug/xdebug-profiler"
没讲到的配置,你们自行查阅文档,太懒会变成猪的!!!
最后一步就是IDEA
,也即IDE
的配置了。主要有两方面要配置:
其一,监听端口配置,对于IDEA
系列,能够在配置中搜索Debug
或者xdebug
就能迅速定位了,图三是个人配置。
图三
其二,是本地开发路径和远程路径的映射配置,也就是要让本地代码和远程代码能够对应起来。配置位置在项目的Run/Debug Configuration
里面,也就是去新建一个调试项目,截图以下。
图四
图五
按照图五中配置好mapping关系后,开始使用xdebug
的调试功能吧,告别简单粗暴甚至低效的echo
输出调试吧!
使用echo
输出调试,不少时候是由于开发者懒,懒得集成调试工具,懒得去优化本身的开发环境。碰到小bug使用echo
还行,一旦遇到诡异bug或者复杂的框架,牢牢靠echo
已然无能为力。固然,单步调试的另外一个好处是可让初学者快速掌握项目的架构和执行流程。
书山有路勤为径,学海无涯苦做舟!!!