php代码分析工具,php7下xhprof性能分析工具的安装与使用的图文代码教程

安装 xhprofcd xhprof/extension/

phpize

./configure

makemake install

然后在/etc/php.ini中根据情况加入extension=xhprof.so

执行php -m | grep xhprof

可以看见输出,说明php扩展安装成功,然后重启Apache或者php-fpm

运行

可以直接运行从github上clone下来的文件里面example目录下的那个例子

输出如下Array

( [main()] => Array ( [ct] => 1 [wt] => 9 ))

---------------Assuming you have set up the http based UI for

XHProf at some address, you can view run at

http:///index.php?run=592567308784c&source=xhprof_foo

---------------

然后复制index.php后面的?run=592567308784c&source=xhprof_foo

访问xhprof_html/index.php?run=592567308784c&source=xhprof_foo

可看见输出

48c0ec3579724b7af4c24c69425e7cc4.png

点击中间的 View Full Callgraph 即可看见性能分析图片

报错failed to execute cmd:" dot -Tpng". stderr:sh: dot:command not found。//解决方案yum install graphviz

随机应变

比如想测试自己的项目,例如一款框架的性能分析。

复制xhprof_lib/utils/下的两个文件

xhprof_lib.php和xhprof_runs.php到入口文件同级目录,然后在入口文件起始位置添加// start profiling

xhprof_enable();

结束位置添加// stop profiler

$xhprof_data = xhprof_disable();

// display raw xhprof data for the profiler run

print_r($xhprof_data);

include_once "xhprof_lib.php";

include_once "xhprof_runs.php";

// save raw data for this profiler run using default

// implementation of iXHProfRuns.

$xhprof_runs = new XHProfRuns_Default();

// save the run under a namespace "xhprof_foo"

$run_id = $xhprof_runs->save_run($xhprof_data, "xhprof_foo");

echo "---------------\n".

"Assuming you have set up the http based UI for \n".

"XHProf at some address, you can view run at \n".

"http:///index.php?run=$run_id&source=xhprof_foo\n".

"---------------\n";

即可得到如上所示的那个url,然后再次去访问http://***/xhprof_html/index.php?run=*****&source=xhprof_foo

得到如下所示页面

3e1a841fe57c374c590a5da1ac96dcf6.png

查看图片

4d5d91bb63f4cb5fa05d8e2c683bb317.png

图中红色的部分为性能比较低,耗时比较长的部分,我们可以根据根据哪些函数被标记为红色对系统的代码进行优化

补充Function Name:方法名称。

Calls:方法被调用的次数。

Calls%:方法调用次数在同级方法总数调用次数中所占的百分比。

Incl.Wall Time(microsec):方法执行花费的时间,包括子方法的执行时间。(单位:微秒)

IWall%:方法执行花费的时间百分比。

Excl. Wall Time(microsec):方法本身执行花费的时间,不包括子方法的执行时间。(单位:微秒)

EWall%:方法本身执行花费的时间百分比。

Incl. CPU(microsecs):方法执行花费的CPU时间,包括子方法的执行时间。(单位:微秒)

ICpu%:方法执行花费的CPU时间百分比。

Excl. CPU(microsec):方法本身执行花费的CPU时间,不包括子方法的执行时间。(单位:微秒)

ECPU%:方法本身执行花费的CPU时间百分比。

Incl.MemUse(bytes):方法执行占用的内存,包括子方法执行占用的内存。(单位:字节)

IMemUse%:方法执行占用的内存百分比。

Excl.MemUse(bytes):方法本身执行占用的内存,不包括子方法执行占用的内存。(单位:字节)

EMemUse%:方法本身执行占用的内存百分比。

Incl.PeakMemUse(bytes):Incl.MemUse峰值。(单位:字节)

IPeakMemUse%:Incl.MemUse峰值百分比。

Excl.PeakMemUse(bytes):Excl.MemUse峰值。单位:(字节)

EPeakMemUse%:Excl.MemUse峰值百分比。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值