调试PHP时,XDebug一直是大众的不二选择,搭配上Webgrind,可以获得不错的效果。今天看某人的栖息地里的介绍,才发现了XHProf,于是体验了一下,感觉很酷,与XDebug相比,运行更轻便(本身还包括一个web查看工具),表现更易懂,下面记录一下体验过程。

1.安装XHProf

Command代码
  1. wget http://pecl.php.net/get/xhprof-0.9.2.tgz
  2. tar zxf xhprof-0.9.2.tgz
  3. cd xhprof-0.9.2
  4. cp -r xhprof_html xhprof_lib <directory_for_htdocs>
  5. cd extension
  6. phpize
  7. ./configure
  8. make
  9. make install

2 . 配置php.ini

Php.ini代码
  1. [xhprof]
  2. extension=xhprof.so
  3. ;
  4. ; directory used by default implementation of the iXHProfRuns
  5. ; interface (namely, the XHProfRuns_Default class) for storing
  6. ; XHProf runs.
  7. ;
  8. xhprof.output_dir=<directory_for_storing_xhprof_runs>

重启服务让修改生效,现在就可以使用XHProf了,不过为了显示效果更炫,最好继续安装Graphviz。

3. 安装Graphviz

Command代码
  1. wget http://www.graphviz.org/pub/graphviz/stable/SOURCES/graphviz-2.24.0.tar.gz
  2. tar zxf graphviz-2.24.0.tar.gz
  3. cd graphviz-2.24.0
  4. ./configure
  5. make
  6. make install

安装Graphviz的目的是为了xhprof图形化web工具查看profiling log文件。安装后使用web工具查看log图形时,最常见错误是: 
提示如下:

引用
Error: either we can not find profile data for run_id 4d7f0bd99a12f or the threshold 0.01 is too small or you do not have ‘dot’ image generation utility installed.

且编译graphviz提示信息png: No (missing png.h),也就是dot 不支持PNG,所以需要安装libpng包,如:

Linux代码
  1. wget http://nchc.dl.sourceforge.net/project/libpng/libpng15/1.5.1/libpng-1.5.1.tar.gz
  2. tar zxf libpng-1.5.1.tar.gz
  3. cd libpng-1.5.1
  4. ./configure
  5. make
  6. make install

然后重新编译安装graphviz,加上参数--with-png=yes。完成后,应确保命令dot在PATH环境变量里(默认应该就在路径里,一般不需要特别设置),以便XHProf能找到它。

使用XHProf  
在你要监测的Php代码头尾部分别加入代码xhprof_enable()和xhprof_disable()

Php代码
  1. // start profiling
  2. xhprof_enable();
  3. // xhprof_enable(XHPROF_FLAGS_CPU + XHPROF_FLAGS_MEMORY); // 允许CPU和内存输出
  4. // run program
  5. ....
  6. // stop profiler
  7. $xhprof_data = xhprof_disable();
  8. //
  9. // Saving the XHProf run
  10. // using the default implementation of iXHProfRuns.
  11. //
  12. $XHPROF_ROOT = "/projects/xhprof";//这里填写的就是你的xhprof的路径
  13. include_once $XHPROF_ROOT . "/xhprof_lib/utils/xhprof_lib.php";
  14. include_once $XHPROF_ROOT . "/xhprof_lib/utils/xhprof_runs.php";
  15. $xhprof_runs = new XHProfRuns_Default();
  16. // Save the run under a namespace "xhprof_foo".
  17. //
  18. // **NOTE**:
  19. // By default save_run() will automatically generate a unique
  20. // run id for you. [You can override that behavior by passing
  21. // a run id (optional arg) to the save_run() method instead.]
  22. //
  23. $run_id = $xhprof_runs->save_run($xhprof_data, "xhprof_foo");
  24. echo "---------------\n".
  25. "Assuming you have set up the http based UI for \n".
  26. "XHProf at some address, you can view run at \n".
  27. "http://<xhprof-ui-address>/index.php?run=$run_id&source=xhprof_foo\n".
  28. "---------------\n";

如此一来,会在上面设定的xhprof.output_dir目录里生成名字类似49bafaa3a3f66.xhprof_foo的数据文件,可以很方便的通过Web方式浏览效果:

http://<xhprof-ui-address>/index.php?run=49bafaa3a3f66&source=xhprof_foo

目前显示的是表格形式的显示,点击页面上的[View Full Callgraph],就能看到精美的图片显示了。看看下面的screenshot.


结果分析

引用

主要指标:
Inclusive Time (或子树时间):包括子函数所有执行时间。
Exclusive Time/Self Time:函数执行本身花费的时间,不包括子树执行时间。
Wall时间:花去了的时间或挂钟时间。
CPU时间:用户耗的时间+内核耗的时间

# 如果xhprof_enable函数写作:xhprof_enable(XHPROF_FLAGS_CPU + XHPROF_FLAGS_MEMORY)可以输出更多指标。
Function Name 函数名
Calls 调用次数
Calls% 调用百分比

# 消耗时间
Incl. Wall Time (microsec) 调用的包括子函数所有花费时间 以微秒算(一百万分之一秒)
IWall% 调用的包括子函数所有花费时间的百分比
Excl. Wall Time (microsec) 函数执行本身花费的时间,不包括子树执行时间,以微秒算(一百万分之一秒)
EWall% 函数执行本身花费的时间的百分比,不包括子树执行时间

# 消耗CPU
Incl. CPU(microsecs) 调用的包括子函数所有花费的cpu时间。减Incl. Wall Time即为等待cpu的时间
ICpu% Incl. CPU(microsecs)的百分比
Excl. CPU(microsec) 函数执行本身花费的cpu时间,不包括子树执行时间,以微秒算(一百万分之一秒)。
ECPU% Excl. CPU(microsec)的百分比

# 消耗内存
Incl.MemUse(bytes) 包括子函数执行使用的内存。
IMemUse% Incl.MemUse(bytes)的百分比
Excl.MemUse(bytes) 函数执行本身内存,以字节算
EMemUse% Excl.MemUse(bytes)的百分比

# 消耗内存峰值
Incl.PeakMemUse(bytes) Incl.MemUse的峰值
IPeakMemUse% Incl.PeakMemUse(bytes) 的峰值百分比
Excl.PeakMemUse(bytes) Excl.MemUse的峰值
EPeakMemUse% EMemUse% 峰值百分比

来源:http://koda.iteye.com/blog/463891

体验XHProf(linux版本)相关推荐

  1. 百度网盘Linux版本能用吗,百度网盘Linux版使用体验效果

    以下是百度网盘Linux版使用体验效果分享,它可以在LinuxMint 19.1操作系统中运行. 前言 百度推出了重量级Linux软件,即百度网盘Linux版,这是一款百度推出的官方Linux客户端, ...

  2. 在Ubuntu 14.04 64bit上安装网易云音乐Linux版本(最新官方版)

    在Chrome浏览器中,登陆官网下载Linux版本中的Ubuntu 16.04 64bit的deb包 http://music.163.com/#/download 下载完成后,双击该deb包即可自动 ...

  3. Linux版本划分——基于打包方式

    基于Dpkg (Debian系) Debian GNU / Linux是一种强调使用自由软件的发行版.它支持多种硬件平台.Debian及其派生发行版使用deb软件包格式,并使用dpkg及其前端作为包管 ...

  4. linux ubuntu fadora,两大主流Linux版本Ubuntu 18.04和Fedora 28的对比

    以下为你带来当前两大主流Linux版本Ubuntu 18.04和Fedora 28它们之间的对比,这两个版本都有自身独自的的包管理,Ubuntu使用的是DEB,而Fedora使用RPM,不过它们都共同 ...

  5. CentOS VS Ubuntu,谁才是更好的 Linux 版本?

    几乎所有新手刚接触 Linux 时,都会被它众多的发行版本搞得一头雾水,截至目前,Linux 已经有几百个发行版本-- 从技术上来说,Linux 只是一个内核,内核指的是一个提供设备驱动.文件系统.进 ...

  6. 浏览器linux版本,Opera浏览器电脑版|Opera浏览器 V60.0.3255.70 Linux版 下载_当下软件园_软件下载...

    Opera浏览器是一款非常好用的浏览器,这个版本是Linux版本,它能够帮助用户进行网络同步,Wand密码管理.会话管理.鼠标手势.键盘快捷键等非常好用的功能,当然可不止这些哦,喜欢的用户赶快来下载吧 ...

  7. 个人linux版本管理,浅谈各个Linux版本的个人看法

    Android Android手机是一个基于Linux内核的操作系统,这个版本相信大家没有异议,因为与iphone手机可以相提并论以外,就是最好用的操作系统,当然这应该是局限以移动端设备,因为它就是为 ...

  8. linux 安装qq,如何安装linux版本QQ?

    layout: page title: linuxQQ发布 description: linuxQQ安装 tags: Linux qq categories: linux 前文 时光匆匆,随着时间流逝 ...

  9. linux右上角不显示网络连接_来体验下Linux吧

    在前面的几期中我们从树莓派开始了解Linux,大家可能已经想来试一下手了.趁热打铁,本期我将介绍两种方便体验学习Linux的方法,在线体验或者安装虚拟机. 1 在线体验Linux 如果想快速的体验下L ...

最新文章

  1. 17、Kubernetes容器交付介绍
  2. 谷歌ALBERT模型V2+中文版来了:之前刷新NLP各大基准,现在GitHub热榜第二
  3. 主成分分析法_“主成分分析法”——线上讨论会等你加入
  4. 极客编程日历桌面版for mac开发笔记[swift]
  5. ASP.NET MVC 3 RC发布
  6. H5_canvas与svg
  7. 直播 | NeurIPS 2021:基于投影变换建模传递关系的知识图谱表示学习
  8. matlab实现脑电信号的相位同步分析,视听刺激脑电信号的相位同步分析
  9. 儒林外史每回概括简短10字_早安心语正能量经典短句 一句话的简短励志语录
  10. vue echarts动态数据定时刷新
  11. 借助创客匠人玩转视频号
  12. 四象限原则+番茄时间管理法
  13. rtl 8111 linux 驱动,【驱动】在LINUX(ubuntu)系统下安装RTL8111/8168网卡驱动程序(技嘉H61主板)...
  14. c++类模板用法讲解
  15. Serval and Rooted Tree(CF1153D)-DP
  16. Power BI中突出显示矩阵的最大值与最小值
  17. 蜗店SaaS系统功能介绍
  18. [渝粤教育] 西南科技大学 统计学原理 在线考试复习资料(3)
  19. android动态贴纸实现原理,人脸动态贴纸sdk算法详解,人脸动态贴纸功能如何实现...
  20. 做为一名大数据新手,如何成为大数据工程师?附上学习路线

热门文章

  1. java什么是对象如何创建对象_java对象的创建过程是什么
  2. 「MacOS」无法打开***,因为无法验证开发者。
  3. User-Agent-Switcher和fiddler
  4. shell编程--基本格式,基本语法,运算符,expr,(()),$[]
  5. 13-jdbc分页+事务
  6. php中引入shiro,基于shiro的自定义注解的扩展-图文详解
  7. mysql多实例访问代理_MySql-Proxy之多路结果集归并
  8. Linux驱动编程 step-by-step (四) 字符设备的注册与设备节点的自动创建
  9. C++类的基本学习知识
  10. 解决mysql表不能查询修改删除等操作并出现卡死