1 安装 xdebug , kcachegrind, wincacehgrind
无论是KCachegrind 还是 WinCachegrind 都需要 XDebug 的支持,所以先来安装XDebug
XDebug 官方网站为:http://www.xdebug.org/,根据你的系统下载队对应的动态连接库
修改 php.ini 文件
添加xdebug 扩展库,添加如下内容:
[XDebug]
zend_extension_ts="/xampp/php/ext/php_xdebug.dll" (xdebug动态连接库的位置)
xdebug.profiler_output_dir="/xampp/tmp/xdebug-profile" (用来存放性能分析文件)
重启apache ,查看phpinfo()信息,如果出现 xdebug相关信息则说名安装成功。如下图:
安装:kcachegrind ,由于kcachegrind只能在kde环境下运行,所以需要安装 kdewin-installer-gui
下载地址为:http://winkde.org/pub/kde/ports/win32/installer/
安装 kdewin-installer-gui 时选择全部安装(为了省事~~,其中也包括了kcachegrind)
另外在windows下 kcachegrind 需要dot(linux下的画图工具,有windows版的,在graphviz工具集中的,http://www.graphviz.org/)的支持
安装: wincachegrind
下载地址:http://sourceforge.net/projects/wincachegrind/
2 编写测试文件
main.php
<?php
for($i = 0;$i<10000;$i++)
{
echo 'IN THE FILE '.__FILE__.'<br>';
}
require 'f1.inc.php';
require 'f2.inc.php';
?>
f1.inc.php
<?php
for($i = 0;$i<10000;$i++)
{
echo 'IN THE FILE '.__FILE__.'<br>';
}
?>
f2.inc.php
<?php
for($i = 0;$i<10000;$i++)
{
echo 'IN THE FILE '.__FILE__.'<br>';
}
?>
3 测试: 访问 http://127.0.0.1/main.php
性能分析文件会在 /xampp/tmp/xdebug-profile 目录下生成 文件名例如:cachegrind.out.576
用 kcachegrind 打开该文件,如下图:
用 wincachegrind 打开该文件,如下图:
kcachegrind 要比 wincacehgrind友好的多
kcachegrind 的使用教程可以访问 http://docs.kde.org/stable/en/kdesdk/kcachegrind/index.html