这篇文章的标题原来叫《用 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 受难记之(1)相关推荐

  1. Windows 下安装 Xdebug 受难记之(2)

    于是,转移到另一台安装 Windows Server 2003 + PHP5.2.5 的机器,按照前述的步骤,安装 Xdebug 2.1.0.可以看到 phpinfo 中的 Xdebug 信息了.但运 ...

  2. Windows 下安装 Xdebug 受难记之(3)

    正式开始<用 Xdebug 进行基准测试和代码覆盖率分析>. 一.使用 Xdebug 进行基准测试 可以使用以下函数获取基准测试信息. int xdebug_memory_usage() ...

  3. python开发工具及环境配置_python_在windows下安装配置python开发环境及Ulipad开发工具...

    最近开始学习Python,在网上寻找一下比较好的IDE.因为以前用C#做开发的,用Visual Studio作为IDE,鉴于用惯了VS这么强大的IDE,所以对IDE有一定的依赖性. Python的ID ...

  4. 基于svnserve的SVN服务器(windows下安装与配置)

    基于svnserve的SVN服务器(windows下安装与配置) 关键字: svn 安装SVNserve 从http://subversion.tigris.org/servlets/ProjectD ...

  5. Windows下安装Z3的Python3版

    文章目录 Windows下安装Z3的Python3版 pip 安装(不推荐,很慢) 使用微软官方构建好的DLL(推荐,快速) Windows下安装Z3的Python3版 GitHub官方仓库地址:Z3 ...

  6. 在windows下安装concurrentlua

    concurrentlua的makefile只提供了unix下的版本,如果直接按make里面得拷贝路径安排文件 在windows下是无法凑效的.这里我把我在windows下安装concurrentlu ...

  7. linux/windows下安装scala

    为什么80%的码农都做不了架构师?>>>    一.linux下安装scala 1.保证jdk安装成功,版本在1.5或者更改版本,java和javac均可用. 2.官网下载scala ...

  8. windows下安装cygwin及配置

    windows下安装cygwin及配置 对于使用Windows操作系统作为开发平台同时又喜欢类unix环境的朋友(Windows不是最方便的开发环境),这里是在Cygwin环境下安装Rails的步骤 ...

  9. Redis第一集:Windows下安装Redis和测试

    Redis第一集:Windows下安装Redis和测试 一.资源 Windows下的Redis的下载地址 点击这里即可下载,如果进不去GitHub的话,可以上网搜一下怎么进GitHub,搭个梯子(●ˇ ...

最新文章

  1. 微软官方再次上线了Python教程,这次比较高级
  2. 为什么说 TCP/IP 是一个不确定性网络
  3. SQL查询效率:100w数据查询只需要1秒钟
  4. web 攻击靶机解题过程
  5. 线程间的通信方式1--共享变量(内存)
  6. java操作word文档,深度解析,值得收藏
  7. 山东大学 2020级数据库系统 实验二
  8. JAVA语言怎么搞_Java语言
  9. python操作各种excel库
  10. iOS8中添加的extensions总结(一)——今日扩展
  11. linux将文件的第二列求和,awk实现第一列相乘,第二列求和,并相加 - 米扑博客...
  12. html5之Canvas坐标变换应用-时钟实例
  13. MyBatis入门到精通,最全最详细的MyBatis学习教程来了
  14. 业余无线电通信_业余电台操作证书查询方式
  15. 前端实习一个多月总结
  16. iTunes 12.7降级
  17. 操作系统复习笔记--第十一、十二章 文件系统的实现与大容量存储结构
  18. 学习路之数据库:sql查询时添加一列固定值
  19. 奥密克戎“后遗症”,比病毒更可怕
  20. 微信小程序实现图片文字识别提取

热门文章

  1. 面朝大海, 春暖花开
  2. 刘鹏教授受邀参加秦淮知识产权日主题宣传 · 圆桌论坛
  3. Go语言内嵌C语言教程
  4. 用python编程、假设一年期定期利率_第二章-习题答案
  5. 屏幕录像专家 V7.5 Build 20080112 简体中文绿色特别版
  6. ORA-01109:数据库未打开 解决办法
  7. 三月已逝,接下来是忙碌的四月
  8. redis客户端 predis与phpredis 比较
  9. 使用turtle绘制心心相印(动态)python
  10. 南京大学java机试,2019南京大学计算机本科生开放日机试