早就听说了xhprof这款由facebook开源的php性能分析工具了,只是一直没有使用过,因为工作中从来没有对代码进行过性能分析.目前项目的代码中集成了xhprof,所以最近抽空下载,安装试用了下.特此记录.


要想让xhprof能够正常运行,需要安装以下扩展.

1,libpng提供给graphviz试用,yum自带

2.graphviz,xhprof需要用它绘图,需要自己下载 wget http://www.graphviz.org/pub/graphviz/stable/SOURCES/graphviz-2.24.0.tar.gz

3.xhprof


在编译安装xhprof过程中,出现了error 1的bug,导致make错误.安装失败

最后更换了xhprof的版本才通过


xhprof文件中有两个重要的文件目录:

1,xhprof_html,这个目录中有个docs目录,里面有关于xhprof的文档.另外xhprof的分析结果文件需要使用xhprof_html中的index.php文件进行结果显示

2,xhprof_lib,这个目录就是代码中需要引入的文件

这两个目录都要放到站点下面.xhprof_html可以放到单独的站点下,这样就可以通过独立的域名查看分析结果

3.examples,这个目录下的sample.php是个测试文件


编译安装xhprof之后需要在php.ini中对此扩展进行设置

extension=xhprof.so

xhprof.output_dir=/www/logs/xhprof ,这里指定xhprof生成的分析结果文件,此目录要实现建立,并需要有写权限


编写测试代码:

<?phpfunctionbar($x){if($x>0){bar($x-1);}}functionfoo(){for($idx=0;$idx<2;$idx++){bar($idx);$x=strlen("abc");}}xhprof_enable(XHPROF_FLAGS_CPU+XHPROF_FLAGS_MEMORY);//代码的开头指定//xhprof_enable(XHPROF_FLAGS_NO_BUILTINS);不记录内置的函数//xhprof_enable(XHPROF_FLAGS_CPU+XHPROF_FLAGS_MEMORY);同时分析CPU和Mem的开销foo();//需要测试的代码$xhprof_data=xhprof_disable();include_once"xhprof_lib/utils/xhprof_lib.php";include_once"xhprof_lib/utils/xhprof_runs.php";$xhprof_runs=newXHProfRuns_Default();$run_id=$xhprof_runs->save_run($xhprof_data,"hx");//$run_id.hx.xhprof就是生成的分析结果文件,写入到xhprof.output_dir目录中,'hx'在文档中称为namespace$url=$xhprof_root."/xhprof_html/index.php?run=$run_id&source=hx";//$xhprof_root就是访问xhprof_html的域名echo''.$url.'';


在浏览器中打开此$url就能看到分析结果了


Function Name 函数名

Calls 调用次数

Calls% 调用百分比

Incl. Wall Time (microsec) 调用的包括子函数所有花费时间 以微秒算(一百万分之一秒)

IWall% 调用的包括子函数所有花费时间的百分比

Excl. Wall Time (microsec) 函数执行本身花费的时间,不包括子树执行时间,以微秒算(一百万分之一秒)

EWall% 函数执行本身花费的时间的百分比,不包括子树执行时间

Incl. CPU(microsecs) 调用的包括子函数所有花费的cpu时间。减Incl. Wall Time即为等待cpu的时间

减Excl. 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% 峰值百分比