php性能分析工具xhprof的安装使用
更新:HHH   时间:2023-1-7


早就听说了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生成的分析结果文件,此目录要实现建立,并需要有写权限


编写测试代码:

<?php
function bar($x) {
  if ($x > 0) {
    bar($x - 1);
  }
}
function foo() {
  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 = new XHProfRuns_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% 峰值百分比  


返回web开发教程...