PHP扩展下载:https://pecl.php.net/package/xhprof
php.ini配置
[xhprof]
extension=xhprof
xhprof.output_dir=/temp/xhprof
auto_prepend_file = /temp/inject_xhprof.php
if(php_sapi_name() == 'cli')
{
return;
}
$xhprof_config['enabled']=1;
if(!empty($xhprof_config['enabled']))
{
xhprof_enable(XHPROF_FLAGS_CPU + XHPROF_FLAGS_MEMORY);
register_shutdown_function('shutdown');
}
function shutdown()
{
$xhprof_data = xhprof_disable();
include_once "C:\php-7.2.16-Win32-VC15-x64/xhprof_lib/utils/xhprof_lib.php";
include_once "C:\php-7.2.16-Win32-VC15-x64/xhprof_lib/utils/xhprof_runs.php";
$objXhprofRun = new XHProfRuns_Default();
$run_id = $objXhprofRun->save_run($xhprof_data, "xhprof");
//此处空间很大
if(function_exists('fastcgi_finish_request')){
var_dump($run_id);
fastcgi_finish_request();
}
}
web查看在http://localhost/xhprof_html/index.php
将xhprof_html拷贝到单独的目录下,配置独立的域名,这样可以更方便的管理
运行指标与火焰图运行函数分析
参数说明:
Function Name:方法名
Calls:方法被调用次数
Calls%方法调用次数在同级方法总数调用次数中所占的百分比
Incl.Wall Time:方法执行花费的时间 (包含子函数)
IWal% 方法执行所花时间的百分比
Excl.WallTIme方法本身执行所花时间(不包含子函数)
Ewall%方法本身执行所花费的百分比
Incl.CPU方法执行所花费的CPU时间(包含子)
ICPU方法所花费的CPU时间的百分比
Excl.CPU方法本身执行所花费的CPU时间(不包含子)
ECPU%方法本身执行花费的CPU时间百分比
Incl.MemUse:方法执行占用内存(包含子函数)
IMemUse%:方法执行占用内存百分比
Excl.MemUse:方法本身执行占用内存(不包含子)
EMenUse%方法本身执行占用内存百分比
Incl.PeakMemUse :Incl.MenUse峰值
IPeakMemUse:Incl.MemUse峰值百分比
Excl.PeakMemUse:Excl.MemUse峰值
EPeakMemUse%:E xcl.MemUse峰值百分比