这篇文章的标题原来叫《用 Xdebug 进行基准测试和代码覆盖率分析》。安装 Xdebug 只是文章开头的准备工作之一。然而。仅仅是 Xdebug 的安装,就花费大量的精力和时间,再次感受了开源软件产品的 Bug 引起的磨难和困惑!
只能在这篇文章的第二部分,主要叙述用 Xdebug 进行基准测试和代码覆盖率分析的内容了。
原文的开头写到:
作为一个 PHP 程序员,你了解自己的代码 - 函数、类,在运行时占用多少内存、耗费了多少CPU时间?哪些代码导致了整个系统的效率大大下降?你了解自己的哪些代码是经常被调用的,而哪些代码可能从来就没有被运行过?……
以上的问题,我们需要通过基准测试和代码覆盖率分析(code coverage analysis)来获得有关信息,从而为优化系统提供分析依据。Xdebug 就是解决上述问题的良好工具之一。
Xdebug 是 PHP 开发环境下一个开放源代码的程序调试器(Debug工具),可以用来跟踪,调试和分析 PHP 程序的运行状况。截至 2010年8月份,Xdebug的最新版本是Xdebug 2.1.0,支持PHP4/PHP5。Xdebug 的官方网站是 http://www.xdebug.org,可以去那里了解 Xdebug 的详细信息和下载相关的软件。
一、下载和安装:
在 Windows 下和 Linux 下,Xdebug 的安装方法不尽相同。本文以 Windows 下的安装来描述。在 Windows 下,通过运行 PECL 命令来安装 Xdebug,会提示以下错误:
C:\Program Files\Zend\ZendServer\bin>pecl install xdebug
downloading xdebug-2.1.0.tgz ...
Starting to download xdebug-2.1.0.tgz (301,354 bytes)
.........................done: 301,354 bytes
66 source files, building
WARNING: php_bin C:\Program Files\Zend\ZendServer\bin\.\php.exe appears to have
a suffix .exe, but config variable php_suffix does not match
ERROR: The DSP xdebug.dsp does not exist.
这是在试图编译 Xdebug 时,无法找到 xdebug.dsp 文件导致的。
-- 第一次困惑:既然不能在 Windows 下安装,为什么还能下载?错误信息只提示结果,并没有提供解决的方法。也没有提示去哪里寻找解决方案。
我们可以去 Xdebug 的官网,直接下载对应的 PHP 和 Windows 版本的、已经编译好的二进制 Xdebug 扩展库文件(*.dll)。一定要注意下载和自己安装的 PHP 及 Windows 版本对应的 Xdebug 文件。
可以通过 phpinfo() 函数获取自己的 PHP 信息(本人用的是 Zend Server 5.0.1)。注意 PHP 版本?操作系统的位数(32bit/64bit)?PHP 是线程安全的还是非线程安全的?当前加载的 php.ini 文件的路径。
PHP Version 5.3.2
System:Windows NT WIN2003-1 5.2 build 3790 (Windows Server 2003 R2 Enterprise Edition Service Pack 2) i586
Compiler:MSVC9 (Visual C++ 2008)
Architecture:x86
Loaded Configuration File:C:\Program Files\Zend\ZendServer\etc\php.ini
Thread Safety:disabled
可以看到,本人的操作系统为 Windows Server 2003 企业版,32bit 版本,PHP 版本为 5.3.2,PHP 是用微软的 Visual Studio 2008 下的 VC9 编译的。
于是,下载的 Xdebug 版本为:
Windows binaries,5.3 VC9 Non-thread-safe (32 bit),也就是 php_xdebug-2.1.0-5.3-vc9-nts.dll 文件。
-- 但是,我忽略了我使用的 PHP 环境是 Zend Server CE 5.0.1。于是,隐患就此埋下了……
二、安装配置:
在 php.ini 文件末尾加:
[Xdebug]
zend_extension="C:\Program Files\Zend\ZendServer\lib\php_xdebug-2.1.0-5.3-vc9-nts.dll"
xdebug.auto_trace=On
xdebug.collect_params=On
xdebug.collect_return=On
xdebug.trace_output_dir="C:\Program Files\Zend\ZendServer\xdebug.trace_output_dir"
xdebug.profiler_enable=On
xdebug.profiler_output_dir="C:\Program Files\Zend\ZendServer\xdebug.profiler_output_dir"
注意:
1,在 PHP5.3 里,zend_extension 不能写为 zend_extension_ts,这在 Xdebug 的官网里写的很清楚,虽然是洋文,我注意到了,没掉到陷阱里。也许 5.3 以后的版本,永远就是这样了。
2,xdebug.trace_output_dir 和 xdebug.profiler_output_dir 文件夹组要自己建立,用于存放 Xdebug 生成的文档。
3,xdebug.* = On/Off 等配置语句的意义,本文的第二部分会写。
4,配置好后,需要重新启动 Apache,对应的 Windows 服务的名字为“apache2.2-zend”。Zend Server 的后台管理里(地址http://localhost:10081/zendserver),也可以重启服务。
5,如果 php_xdebug-*.dll 文件选择错了,比如选择了 php_xdebug-2.1.0-5.3-vc6.dll,那么运行“php -v”命令,会报告:
C:\Program Files\Zend\ZendServer\bin>php -v
Cannot load Xdebug - it was built with configuration API220090626,NTS,VC6,
where as running engine is API220090626,NTS,VC9
6,php.ini 中开启了的 ZendExtensionManager.dll 和 zendOptimizer,可能会影响 Xdebug 的启用,如果有影响,请屏蔽它们。
Apache 可以正常重启。以为配置好了,但是在 phpinfo() 信息里,无法看到 Xdebug 的信息,说明 Xdebug 的 Zend 扩展模块没有被加载。这时,运行“php -v”命令,居然没有输出信息。
三、柳暗花明
再次浏览 Xdebug 官网,发现有一个贴心的服务,就是:提取用户的 phpinfo 信息,提交给 Xdebug 官网的一个程序,它立即分析 PHP 环境的信息,即刻给出下载 Xdebug 某个版本的建议。立等可取,有点意思!
于是提交我的 phpinfo 信息,从 http://www.xdebug.org/find-binary.php 页面提交,得到提示信息:
Warning: You seem to be using Zend Server, which is known to cause issues with Xdebug.
It might work, but you're on your own.
1.Download php_xdebug-2.1.0-5.3-vc9-nts.dll
2.Move the downloaded file to C:\Program
3.Open C:\Program Files\Zend\ZendServer\etc\cfg\debugger.ini and put a ; in front of the line that says zend_extension_manager.dir.debugger= so that it says ;zend_extension_manager.dir.debugger=
4.Edit C:\Program Files\Zend\ZendServer\etc\php.ini and add at the begining of the file the line zend_extension = C:\Program\php_xdebug-2.1.0-5.3-vc9-nts.dll
5.Restart the webserver
居然能看出来用的是 Zend Server 啊?实在是高啊!我下载的 Xdebug 版本是对的。但是前头的“Warning”让我心里很凉:
已知 Zend Server 与 Xdebug 一起使用会引起一些问题,能不能工作,你自己负责 - 自己看着办。
但有一条信息很重要,就是第3条,从 debugger.ini 里注释掉 zend_extension_manager.dir.debugger= 语句。注释掉该语句,意味着屏蔽了 zend debugger。看来 zend debugger 和 Xdebug 在 PHP5.3 里不能一起共存啊?以后能不能共存呢?
遵照官方的提示做了以后,Apache 可以正常启动。php -v 命令的提示如下:
C:\Program Files\Zend\ZendServer>php -v
PHP 5.3.2 (cli) (built: Apr 1 2010 17:14:41)
Copyright (c) 1997-2010 The PHP Group
Zend Engine v2.3.0, Copyright (c) 1998-2010 Zend Technologies
with Zend Extension Manager v5.1, Copyright (c) 2003-2010, by Zend Technolog
ies
- with Zend Data Cache v4.0, Copyright (c) 2004-2010, by Zend Technologies [
loaded] [licensed] [disabled]
- with Zend Utils v1.0, Copyright (c) 2004-2010, by Zend Technologies [loade
d] [licensed] [enabled]
- with Zend Optimizer+ v4.1, Copyright (c) 1999-2010, by Zend Technologies [
loaded] [licensed] [disabled]
with Xdebug v2.1.0, Copyright (c) 2002-2010, by Derick Rethans
with Zend Data Cache v4.0, Copyright (c) 2004-2010, by Zend Technologies
with Zend Utils v1.0, Copyright (c) 2004-2010, by Zend Technologies
看来,Xdebug 是被正常加载了!
但是,大问题来了!这时打开浏览器,运行 php 文件,查看 phpinfo 信息,想看看 Xdebug 的信息。但是,这个 php 文件居然被下载下来了!!!也就是说,php 文件不被解析了!
这就意味着,安装 Xdebug 已经没有任何意义了。本来就是要让 Xdebug 跟踪 php 文件运行的有关信息嘛。
于是,在 Zend Server 5.0.1 下,安装 Xdebug 失败。
我的目的是熟悉 Xdebug 的使用,Xdebug 安装失败,我不想自己看着办。
-- 这个开源的 PHP 和 Xdebug 啊,到底是谁错了??!!
作者:张庆(网眼) 西安 PHP 教育培训中心 2010-7-7
来自“网眼视界”:http://blog.why100000.com
作者微博:http://t.qq.com/zhangking
“十万个为什么”电脑学习网:http://www.why100000.com
分享到:
相关推荐
在Windows环境下,安装Xdebug和WinCacheGrind是开发者为了进行PHP性能分析的重要步骤。Xdebug是一个强大的PHP扩展,主要用于调试和性能分析,而WinCacheGrind则是一个可视化的工具,用于解析Xdebug生成的profiling...
windows xp 下 apache + php 安装Xdebug 附件中 含有 Xdebug的dll扩展库文件 和 详细的 安装步骤,如果使用的是 php的其他版本 请到 www.Xdebug.org/download.php 下载相应版本
在sublime text2上安装xdebug
4. **启用Xdebug Helper**: 安装完成后,你可以在浏览器右上角看到一个绿色的 "X" 图标,这表明Xdebug Helper已经启用。点击这个图标可以切换调试模式。 ### 配置 PhpStorm 与 Xdebug 1. **启动 PhpStorm**: 打开...
zend_extension=path/to/xdebug.so # Linux/MacOS下,指向xdebug.so的路径 xdebug.idekey=PHPSTORM # 这里的idekey需要与IDE中的设置一致 xdebug.remote_enable=1 # 开启远程调试 xdebug.remote_host=localhost ...
- 当 `xdebug.show_info` 或 `xdebug.show_local_vars` 设置为 1 时,Xdebug 会在页面底部显示一个包含调试信息的条形栏,方便快速查看状态。 9. **配合版本控制系统** - 如果你在使用 Git 等版本控制系统,可以...
PHP_Xdebug是一款强大的PHP调试工具,尤其在Windows环境下与WAMP(Windows Apache MySQL PHP)服务器组合使用时,它为开发者提供了更深入的错误检测和调试功能。Xdebug不仅有助于捕获运行时错误,还能提供详细的堆栈...
2. **配置 Xdebug**:在服务器端,需安装并配置 Xdebug 扩展,设置适当的配置参数如 `xdebug.remote_enable` 和 `xdebug.idekey`,使其与 Xdebug Helper 插件匹配。 3. **启用/禁用调试**:在浏览器中,点击 Xdebug...
xdebug 安装,调试 版本php7.3.4
对于IDE如VSCode或PHPStorm,需要安装相应的Xdebug插件,并配置调试配置。例如,VSCode中创建`.vscode/launch.json`文件,添加如下内容: ```json { "version": "0.2.0", "configurations": [ { "name": ...
1. Chrome 安装 xdebug 插件,并设置 IDE key。 2. PhpStorm 设置,进入界面,File-setting-Languages&Frameworks-PHP-Servers 设置服务器端 IP、开发端路径、服务器端路径。 3. 如果服务器端端口不是默认的 9000,...
使用Xdebug调试和优化PHP程序系列教程之Xdebug配置,根据Xdebug的官方文档来详细解释Xdebug的参数配置。 Xdebug配置 第一部分:安装 预编译模块 安装预编译模块是很容易的。只需要将它们放到一个目录中,并将下面的...
### PHP调试之Netbeans + xdebug配置全攻略 在PHP开发过程中,经常需要对代码进行调试来确保程序的正确性和高效性。对于PHP开发者来说,一个强大的集成开发环境(IDE)加上一个高效的调试器是非常重要的工具组合。...
1. 登录www.xdebug.org,在首页右侧有一个Windows modules,选择其中的PHP5.1.2+,下载php_xdebug-5.1.2-2.0.0beta6.dll文件; 2. 将下载的php_xdebug-5.1.2-2.0.0beta6.dll放到C:\php5\ext目录,重命名为...
本文详细介绍了Xdebug的安装配置过程以及如何与PHPStorm配合使用进行高效的代码调试。通过以上步骤,开发人员可以充分利用Xdebug的强大功能,提高开发效率,同时也能更好地理解代码执行流程及性能瓶颈。
zend_extension=xdebug.so # Windows下可能为xdebug.dll,路径需对应实际位置 xdebug.default_enable=1 xdebug.remote_enable=1 xdebug.remote_host=localhost xdebug.remote_port=9000 xdebug.idekey="PHPSTORM" # ...
5. 安装XDebug: - XDebug是PHP的一个调试工具,它提供了丰富的调试功能,比如堆栈跟踪、变量查看、错误捕获等。文章指导如何从官方网站下载XDebug的源码包,解压后通过`phpize`来配置环境,并进行编译安装。安装...
安装Xdebug通常涉及以下几个步骤: 1. 下载与PHP版本兼容的Xdebug二进制文件(例如,这里的"xdebug-5.6"针对的是PHP 5.6版本)。 2. 将Xdebug库编译并安装到PHP的扩展目录。 3. 编辑php.ini文件,添加或修改Xdebug的...
三、Linux环境下安装Xdebug 2.5.5 1. 安装依赖:首先确保系统安装了必要的编译工具和PHP开发头文件,如`build-essential`和`php-dev`。 2. 获取源码:通过访问官方网站或使用Git克隆仓库,获取Xdebug 2.5.5的源码...