使用 XHProf 分析你的 PHP 程序
个人说明:
注意:
php5.5运行 xhprof_enable 会发生段错误Segmentation fault: ,这是一个已知的bug。
下面是报错测试脚本:
function loader() {
// <empty>
}
spl_autoload_register('loader', $throw = true);
xhprof_enable();
class_exists('ThisClassDoesNotExist');
echo "OK\n";
引自原文 http://blog.aboutc.net/php/17/php-profiler-xhprof
2014-12-21 -- 测试出问题,尝试以下:http://www.chenglin.name/php/optimization/439.html
简介
XHProf是一个轻量级PHP性能分析工具,类似 xdebug,但比 xdebug 分析的信息更加详细, 包括函数的调用次数,花费的时间(自身花费时间和包含内部函数花费的时间),所占内存/CPU,所占内存的峰值及所占百分比等, 为什么用的是等呢,因为源码包中 xhprof_lib/display/xhprof.php文件里还有一个 Incl. User (microsecs) 和 Incl. Sys (microsec) 没有在结果中显示,有兴趣的同学可以研究研究。
安装
$ wget https://github.com/facebook/xhprof/tarball/master -O xhprof.tar.gz
$ tar zxf xhprof.tar.gz
$ cd facebook-xhprof-b8c76ac/extension/
# phpize
# ./configure --with-php-config=`/path/to/php-config`
# make && make install
# make test
# vi /etc/php.d/xhprof.ini
; 内容为:
extension = xhprof.so
; 注意:output_dir 必须存在且可写
xhprof.output_dir = "/tmp/xhprof"
# service php-fpm restart 或 service httpd restart
当然也可以使用 yum install php-pecl-xhprof 安装, 但是源码包中 xhprof_html 和xhprof_lib 这两个文件夹是需要的,见 使用 web 界面。
简单使用
现在运行下例子看下效果:
$ php -f facebook-xhprof-b8c76ac/examples/sample.php
输出结果略。
输出结果中的含义:
ct 函数调用次数,
wt 花费的时间,
cpu 花费的 CPU 时间(微秒即百万分之一秒),
mu 使用的内存(bytes),
pmu 使用的内存峰值(bytes)。
xhprof_enable 参数
还可以给 xhprof_enable() 传入:
XHPROF_FLAGS_CPU 分析结果中添加 CPU 数据
XHPROF_FLAGS_MEMORY 分析结果中添加内存数据
XHPROF_FLAGS_NO_BUILTINS 跳过 PHP 内置函数
三个参数中的一个或多个,类似这样:
xhprof_enable(XHPROF_FLAGS_NO_BUILTINS);
xhprof_enable(XHPROF_FLAGS_CPU + XHPROF_FLAGS_MEMORY);
xhprof_enable(XHPROF_FLAGS_NO_BUILTINS | XHPROF_FLAGS_CPU | XHPROF_FLAGS_MEMORY);
使用 web 界面
但这样的输出结果在程序较大时对于我们没有实际意义, 在 xhprof 源码包中提供了xhprof_html 和 xhprof_lib两个文件夹是使用 PHP 开发,用于显示 xhprof 分析结果的 web 界面, 比上例输出结果更加详细易读。
$ mkdir /var/www/html/xhprof
$ mv xhprof_html/ xhprof_lib/ examples/ /var/www/html/xhprof/
$ cd /var/www/html/
$ vi xhprof/examples/sample.php
将 `<xhprof-ui-address>` 替换为 `localhost/xhprof/xhprof_html`
/var/www/html 为 DOCUMENT_ROOT 目录。
测试一下,浏览器运行:
http://localhost/xhprof/examples/sample.php
而浏览器输出的内容最后有一个类似这样的链接地址:
http://localhost/xhprof/xhprof_html/index.php?run=50ec187a72aa9&source=xhprof_foo
/tmp/xhprof 目录下会多出一个类似于 50ec187a72aa9.xhprof_foo.xhprof 的文件, 此文件用于存储 xhprof 分析结果的数据信息,作为上述 url 地址的数据来源。
打开这个链接即是 xhprof 的 web 分析结果页面。 这个页面提供了:
Calls:函数的调用次数
Incl. Wall Time (microsec) :包含内部函数花费的时间,单位微秒
Excl. Wall Time (microsec):不包含内部函数花费的时间,单位微秒
及所占百分比(%)
注:Incl.:为 Including 包含的简写
Excl.:为 Excluding 不包含的简写
Wall Time:意为挂钟时间即任务花费的时间
根据此结果页简单解释下 Function Name 列:
main():一个虚构的函数,程序根节点
bar@2:递归调用 2 次
另外 load::filename 和 run_init::filename 是跟踪 PHP 的 include/require 操作。
在此结果中 strlen 和 xhprof_disable 为 PHP 内置函数,如果我们想跳过内置函数不作分析, 并且统计 CPU 和内存使用信息怎么办呢,上面提到过 xhprof_enable 参数, 修改xhprof/examples/sample.php 文件看一下:
将 xhprof_enable(); 行,替换为
xhprof_enable(XHPROF_FLAGS_NO_BUILTINS | XHPROF_FLAGS_CPU | XHPROF_FLAGS_MEMORY);
刷新下页面,再次打开页面最后的 url,这次提供的信息就十分详细了。
Incl. CPU (microsecs):包含内部函数 CPU 花费的时间,单位微秒
Excl. CPU (microsec):不包含内部函数 CPU 花费的时间,单位微秒
Incl. MemUse (bytes):包含内部函数所占内存,单位字节
Excl. MemUse (bytes):不包含内部函数所占内存,单位字节
Incl. PeakMemUse (bytes):包含内部函数所占内存峰值,单位字节
Excl. PeakMemUse (bytes):不包含内部函数所占内存峰值,单位字节
及所占百分比(%)
可以认为共三种情况:
1. 包括内部函数
2. 不包括内部函数或者说函数本身
3. 所占总数(时间或内存使用)的百分比
peak 意为峰值,这里的 CPU 花费时间为什么是 0 呢, 再修改下xhprof/examples/sample.php 文件看一下:
将 foo() 函数中的 for 循环条件 $idx < 5 改为 50
再看一下 web 分析页面结果,CPU 时间出来了。
安装 graphviz
分析结果页中有一个挺明显的 View Full Callgraph 链接, 这个链接是查看整个程序的函数调用流程。使用 graphviz 生成。
# yum install graphviz
编译安装请注意先安装 libpng 依赖。
使用图形展示遇到的错误:
failed to execute cmd: " dot -Tpng". stderr: `sh: dot: command not found '
解决办法:
$ sudo yum install graphviz
参考
net tuts+:http://net.tutsplus.com/tutorials/php/advanced-codeigniter-profiling-with-xhprof/
源码包中的:xhprof_html/docs/index.html
http://www.162cm.com/p/xhprofdoc.html
转载请注明出处。
本文地址:http://blog.aboutc.net/php/17/php-profiler-xhprof
使用 XHProf 分析你的 PHP 程序的更多相关文章
- VSTO学习笔记(七)基于WPF的Excel分析、转换小程序
原文:VSTO学习笔记(七)基于WPF的Excel分析.转换小程序 近期因为工作的需要,要批量处理Excel文件,于是写了一个小程序,来提升工作效率. 小程序的功能是对Excel进行一些分析.验证,然 ...
- vscode源码分析【四】程序启动的逻辑,最初创建的服务
第一篇: vscode源码分析[一]从源码运行vscode 第二篇:vscode源码分析[二]程序的启动逻辑,第一个窗口是如何创建的 第三篇:vscode源码分析[三]程序的启动逻辑,性能问题的追踪 ...
- vscode源码分析【三】程序的启动逻辑,性能问题的追踪
第一篇: vscode源码分析[一]从源码运行vscode 第二篇:vscode源码分析[二]程序的启动逻辑,第一个窗口是如何创建的 启动追踪 代码文件:src\main.js 如果指定了特定的启动参 ...
- 使用XHProf分析PHP性能瓶颈(一)
安装xhprof扩展 wget http://pecl.php.net/get/xhprof-0.9.4.tgz tar zxf xhprof-0.9.4.tgz cd xhprof-0.9.4/ex ...
- 使用xhprof分析php代码性能
推荐在Linux平台使用xhprof,win下xhprof目前稳定版本在php5.5 安装xhprof 下载地址 http://pecl.php.net/get/xhprof-0.9.4.tgz 与p ...
- 使用xhprof分析php性能
今天偶然发现 xhprof可以远程分析php代码性能,大致步骤如下 1. 进入 xhprof , 点击右上角注册 并 登陆, 网站左侧解释了如何在本地安装测试xhprof, 我用的是右侧的图表模式, ...
- springmvc(一) springmvc框架原理分析和简单入门程序
springmvc这个框架真的非常简单,感觉比struts2还更简单,好好沉淀下来学习~ --WH 一.什么是springmvc? 我们知道三层架构的思想,并且如果你知道ssh的话,就会更加透彻的理解 ...
- 使用XHProf分析PHP性能瓶颈(二)
上一篇文章里,我们介绍了如何基于xhprof扩展来分析PHP性能,并记录到日志里,最后使用xhprof扩展自带的UI在web里展示出来.本篇文章将讲述2个知识点: 使用xhgui代替xhprof的默认 ...
- SpringMVC学习(一)———— springmvc框架原理分析和简单入门程序
一.什么是springmvc? 我们知道三层架构的思想,并且如果你知道ssh的话,就会更加透彻的理解这个思想,struts2在web层,spring在中间控制,hibernate在dao层与数据库打交 ...
随机推荐
- Android Preference 设置偏好全攻略
Android 设置是每个App必不可小的东西,看似很简单,但是初学不熟悉的很花时间去研究,特别样式兼容方面,以及有自定义设置的需求,下面是对用法做一个总结 Preference结构 界面结构看下图 ...
- linux初学体会
第一篇随笔,其实是为了写作业,可是老师的要求是对的,其实自己在配环境和做作业的时候也会把遇到的问题的解决方法记录下来,以便以后查找方便.这次借此将那些内容放在这里,也跟大家一起分享下. 上周六算是第二 ...
- spring boot 报错 Error creating bean with name
Application 启动类 要和父目录平级
- spark集群安装部署
通过Ambari(HDP)或者Cloudera Management (CDH)等集群管理服务安装和部署在此不多介绍,只需要在界面直接操作和配置即可,本文主要通过原生安装,熟悉安装配置流程. 1.选取 ...
- 【MFC】学习与问题整合
需要源码联系邮件:kangxlchn@163.com 1.新建一个MFC工程(基于对话框) 环境:vs2017 统统NEXT 新建完成后打开MFCPrj.cpp文件 打开类试图 每创建一个MFC项目, ...
- scatter注记词
say illness thumb ginger brass atom twenty omit fine thought staff poverty
- ssh连接失败, 记下来原因和解决方案
mac下使用secureCRT发现连接不了虚拟机上的linux 运行 ps -e | grep ssh,查看是否有sshd进程 如果没有,说明server没启动,通过 /etc/init.d/sshd ...
- Alpha发布-----欢迎来怼团队
欢迎来怼项目小组—Alpha发布展示 一.小组成员 队长:田继平 成员:葛美义,王伟东,姜珊,邵朔,冉华 ,李圆圆 二.文案+美工展示 链接:http://www.cnblogs.com/wwd199 ...
- activiti工作流已办和待办查询sql
最近项目中遇到一个问题,需要activiti的工作流表和业务表关联分页查询,然而我对于工作流的查询并不太熟悉,所以学习并总结如下. 想看看activiti到底怎么查询的待认领和待办.已办的查询sql, ...
- dataTables工作总结
近期在工作中用到了dataTables,现在总结一下在工作中遇到的问题以及解决方法,如有不妥之处希望多多指教,定会改进. 首先这里用的是coloradmin框架,在vs环境下开发. 这里写一个容器用于 ...