Windows和Linux中php代码调试工具Xdebug的安装与配置详解


Posted in PHP onMay 08, 2014

一、为什么需要Debugger?

很多PHP程序员调试使用echo、print_r()、var_dump()、printf()等,其实对 于有较丰富开发经验的程序员来说这些也已经足够了,他们往往可以在程序执行的过程中,通过输出特定变量的值可以判断程序执行是否正确,甚至效率高低也可以 看出来(当然可能还需要使用一些时间函数)。那么我们为什么还需要一个专门的调试程序来监控我们的程序运行呢? 这个问题的答案不妨留到后面来揭晓。

二、什么是Xdebug?

Xdebug是一个开放源代码的PHP程序调试器(即一个Debug工具),可以用来跟踪,调试和分析PHP程序的运行状况。

三、Windows 下 XDebug 安装与配置

1. 下载XDebug二进制文件: http://www.xdebug.org/download.php
请根据php版本选择下载,例如:

5.2 http://www.xdebug.org/files/php_xdebug-2.1.2-5.2-vc6.dll
5.3 http://www.xdebug.org/files/php_xdebug-2.1.2-5.3-vc6.dll

2. 找到并打开 php.ini 文件
3. 如果配置过 ZendOptimizer, 需要先屏蔽 ZendOptimizer 有关的配置, 通常如下:
[Zend]
zend_extension_manager.optimizer_ts=”path\ZendOptimizer-3.3.0\lib\Optimizer-3.3.0″
zend_extension_ts=”path\ZendOptimizer-3.3.0\lib\ZendExtensionManager.dll”

将其删除或用分号注释掉,如改为:
;[Zend]
;zend_extension_manager.optimizer_ts=”path\ZendOptimizer-3.3.0\lib\Optimizer-3.3.0″
;zend_extension_ts=”path\ZendOptimizer-3.3.0\lib\ZendExtensionManager.dll”

4. 加入 XDebug 配置。参考如下:
[Xdebug]
zend_extension_ts=”path/xdebug/php_xdebug-2.1.2-5.2-vc6.dll”
xdebug.auto_trace=on
xdebug.trace_output_dir=”path\xdebug”
xdebug.profiler_enable=on
xdebug.profiler_output_dir=”path\xdebug”
xdebug.collect_params=on
xdebug.collect_return=on
xdebug.remote_enable=on
xdebug.remote_handler=dbgp
xdebug.remote_host=localhost
xdebug.remote_port=9000

说明:
上面 “path” 的地方需要修改为你自己的本地路径.
参数解释:

zend_extension_ts=”c:/webserver/php5/ext/php_xdebug.dll”
;加载xdebug模块。这里不能用extension=php_xdebug.dll的方式加载,必须要以zend的方式加载,否则安装上后,phpinfo是显示不出xdebug这个项的。
xdebug.auto_trace=on;
;自动打开“监测函数调用过程”的功模。该功能可以在你指定的目录中将函数调用的监测信息以文件的形式输出。此配置项的默认值为off。
xdebug.collect_params=on;
;打开收集“函数参数”的功能。将函数调用的参数值列入函数过程调用的监测信息中。此配置项的默认值为off。
xdebug.collect_return=on
;打开收集“函数返回值”的功能。将函数的返回值列入函数过程调用的监测信息中。此配置项的默认值为off。
xdebug.trace_output_dir=
;设定函数调用监测信息的输出文件的路径。
xdebug.profiler_enable=on
;打开效能监测器。
xdebug.profiler_output_dir=
;设定效能监测信息输出文件的路径。

还有一些更为具体的参数设定,详见:http://www.xdebug.org/docs-settings.php
5. 重启web服务器,如 Apache 或者 IIS
6. 查看 phpinfo 的输出, 如果看到 XDebug 的选项, 就说明配置成功了.
7. 调试信息文件查看。
在本地运行php程序,会在所设定的目录里产生一些调试信息的文件,主要包括:
a. 函数调用过程监测信息文件,文件名格式:trace.××××××.xt。该文件可直接查看,里面包含了函数运行的时间,函数调用的参数值,返回值,所在的文件和位置等信息。内容格式相对直观。
b. 效能监测文件,文件名格式:cachegrind.out.××××××××。
该文件也可以直接查看,但信息格式不易被人类所理解,我们可以安装 wincachegrind 软件,以格式化地读取它。 下载安装方法参考如下:
下载:http://sourceforge.net/projects/wincachegrind/
下载后安装运行,然后点击Tools->options,设定 working folder(php.ini里 xdebug.profiler_output_dir 的值)
这样就可以比较直观的查看效能监测文件的信息了。

四、linux下 XDebug 安装与配置

linux 下可以下载源代码编译安装,方法参考如下。
1.下载对应 php 版本的源代码 source: http://www.xdebug.org/download.php
例如xdebug-2.1.2.tgz版本:http://www.xdebug.org/files/xdebug-2.1.2.tgz
2. 编译安装

tar -xvzf xdebug-2.1.2.tgz
cd xdebug-2.1.2
./configure
make
make install

如果有报错 phpize 没有这个command,那么安装它:
sudo apt-get install php5-dev

3. 将xdebug.so文件移到php5下面
cp modules/xdebug.so /usr/lib/php5/

4. 编辑php.ini,加入下面几行:
[Xdebug]
zend_extension= /usr/lib/php5/xdebug.so
xdebug.profiler_enable=on
xdebug.trace_output_dir=”../xdebug”
xdebug.profiler_output_dir=”../xdebug”

5. 重启Apache,测试是否安装成功

如果输出的内容中有看到xdebug,说明安装配置成功。

PHP 相关文章推荐
最新的php 文件上传模型,支持多文件上传
Aug 13 PHP
php生成随机数的三种方法
Sep 10 PHP
PHP永久登录、记住我功能实现方法和安全做法
Apr 27 PHP
PHP根据session与cookie用户登录状态操作类的代码
May 13 PHP
PHP通过微信跳转的Code参数获取用户的openid(关键代码)
Jul 06 PHP
php判断用户是否关注微信公众号
Jul 22 PHP
PHP将URL转换成短网址的算法分享
Sep 13 PHP
深入讲解PHP的对象注入(Object Injection)
Mar 01 PHP
phpStudy2016 配置多个域名期间遇到的问题小结
Oct 19 PHP
Laravel框架实现的记录SQL日志功能示例
Jun 19 PHP
PHP实现提取多维数组指定一列的方法总结
Dec 04 PHP
Mac M1安装mnmp (Mac+Nginx+MySQL+PHP) 开发环境
Mar 29 PHP
PHP中把stdClass Object转array的几个方法
May 08 #PHP
PHP批量检测并去除文件BOM头代码实例
May 08 #PHP
php代码审计比较有意思的例子
May 07 #PHP
一个php短网址的生成代码(仿微博短网址)
May 07 #PHP
php实现信用卡校验位算法THE LUHN MOD-10示例
May 07 #PHP
php对称加密算法示例
May 07 #PHP
php实现mysql封装类示例
May 07 #PHP
You might like
COM in PHP (winows only)
2006/10/09 PHP
php学习笔记 类的声明与对象实例化
2011/06/13 PHP
PHP迭代器实现斐波纳契数列的函数
2013/11/12 PHP
yii2中使用Active Record模式的方法
2016/01/09 PHP
Yii框架常见缓存应用实例小结
2019/09/09 PHP
jquery 简单图片导航插件jquery.imgNav.js
2010/03/17 Javascript
js实现右下角可关闭最小化div(可用于展示推荐内容)
2013/06/24 Javascript
js中的push和join方法使用介绍
2013/10/08 Javascript
JS根据生日算年龄的方法
2015/05/05 Javascript
深入理解事件冒泡(Bubble)和事件捕捉(capture)
2016/05/28 Javascript
Three.js学习之几何形状
2016/08/01 Javascript
轻松掌握JavaScript状态模式
2016/09/07 Javascript
纯javascript版日历控件
2016/11/24 Javascript
Vue中的$set的使用实例代码
2018/10/08 Javascript
分享5个小技巧让你写出更好的 JavaScript 条件语句
2018/10/20 Javascript
KOA+egg.js集成kafka消息队列的示例
2018/11/09 Javascript
vue-cli 2.*中导入公共less文件的方法步骤
2018/11/22 Javascript
使用node搭建自动发图文微博机器人的方法
2019/03/22 Javascript
简单了解Javscript中兄弟ifream的方法调用
2019/06/17 Javascript
uni app仿微信顶部导航条功能
2019/09/17 Javascript
Vue实现简单的跑马灯
2020/05/25 Javascript
vue使用video插件vue-video-player详解
2020/10/23 Javascript
vue-router路由懒加载及实现的3种方式
2021/02/28 Vue.js
python实现类的静态变量用法实例
2015/05/08 Python
Python lxml模块安装教程
2015/06/02 Python
完美解决在oj中Python的循环输入问题
2018/06/25 Python
python动态进度条的实现代码
2019/07/03 Python
Python callable内置函数原理解析
2020/03/05 Python
Html5剪切板功能的实现代码
2018/06/29 HTML / CSS
大韩航空官方网站:Korean Air
2017/10/25 全球购物
C语言面试题
2015/10/30 面试题
詹天佑教学反思
2014/04/30 职场文书
2014年向国旗敬礼活动总结
2014/09/27 职场文书
2014年音乐教师工作总结
2014/12/03 职场文书
幽默导游词开场白
2015/05/29 职场文书
幼儿园开学报名通知
2015/07/16 职场文书