php性能追踪与分析

PHP扩展下载:https://pecl.php.net/package/xhprof

php.ini配置

[xhprof]

extension=xhprof

xhprof.output_dir=/temp/xhprof

auto_prepend_file = /temp/inject_xhprof.php

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

相关推荐
时光の尘8 分钟前
C语言菜鸟入门·关键字·float以及double的用法
运维·服务器·c语言·开发语言·stm32·单片机·c
以后不吃煲仔饭22 分钟前
Java基础夯实——2.7 线程上下文切换
java·开发语言
进阶的架构师22 分钟前
2024年Java面试题及答案整理(1000+面试题附答案解析)
java·开发语言
前端拾光者26 分钟前
利用D3.js实现数据可视化的简单示例
开发语言·javascript·信息可视化
程序猿阿伟28 分钟前
《C++ 实现区块链:区块时间戳的存储与验证机制解析》
开发语言·c++·区块链
傻啦嘿哟1 小时前
如何使用 Python 开发一个简单的文本数据转换为 Excel 工具
开发语言·python·excel
大数据编程之光1 小时前
Flink Standalone集群模式安装部署全攻略
java·大数据·开发语言·面试·flink
初九之潜龙勿用1 小时前
C#校验画布签名图片是否为空白
开发语言·ui·c#·.net
Dola_Pan1 小时前
C语言:数组转换指针的时机
c语言·开发语言·算法
ExiFengs1 小时前
实际项目Java1.8流处理, Optional常见用法
java·开发语言·spring