php性能分析工具xhprof的安装使用

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

目前创新互联公司已为1000+的企业提供了网站建设、域名、网站空间、网站改版维护、企业网站设计、嵊州网站维护等服务,公司将坚持客户导向、应用为本的策略,正道将秉承"和谐、参与、激情"的文化,与客户和合作伙伴齐心协力一起成长,共同发展。

要想让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就能看到分析结果了

php性能分析工具xhprof的安装使用

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

本文题目:php性能分析工具xhprof的安装使用
文章转载:https://www.cdcxhl.com/article22/gcdhjc.html

成都网站建设公司_创新互联,为您提供品牌网站建设网站收录标签优化企业网站制作动态网站网页设计公司

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联

成都seo排名网站优化