PHP性能测试工具xhprof安装与使用方法详解


Posted in PHP onApril 29, 2018

本文实例分析了PHP性能测试工具xhprof安装与使用方法。分享给大家供大家参考,具体如下:

xhprof概述:

XHProf是一个分层PHP性能分析工具。它报告函数级别的请求次数和各种指标,包括阻塞时间,CPU时间和内存使用情况。一个函数的开销,可细分成调用者和被调用者的开销,XHProf数据收集阶段,它记录调用次数的追踪和包容性的指标弧在动态callgraph的一个程序。它独有的数据计算的报告/后处理阶段。在数据收集时,XHProfd通过检测循环来处理递归的函数调用,并通过给递归调用中每个深度的调用一个有用的命名来避开死循环。XHProf分析报告有助于理解被执行的代码的结构,它有一个简单的HTML的用户界面( PHP写成的)。基于浏览器的性能分析用户界面能更容易查看,或是与同行们分享成果。也能绘制调用关系图。

安装与使用:

最近要做网站的性能对比,于是就找一款性能测试工作来玩玩,工具很多,但相比之前还是觉得xhprof的安装和使用相对来说简单点,数据分析也都还可以,下面就说说它的安装和使用。。。

下载xhprof和graphviz

xhprof的话,直接去php官网就可以下载,为了方便可以戳一下 这里

graphviz的话也要下载,主要是显示xhprof性能结果的图形报表,戳这里 这里

编译安装xhprof

cd xhprof-0.9.4/xhprof-0.9.4/extension/
phpize
./configure
make
sudo make install

将生成的xhprof.so文件加到php.ini文件中,然后重启apache了

...
#这里要使用相对路径加载的话首先要看一下extension_dir配置的路径,或者直接写上`.so`文件的绝对能够路径即可。。。
extension=xhprof.so
...
sudo apachectl restart
##测试扩展是否安装成功,有如下输出则ok
php --ri xhprof
...
 xhprof
 xhprof => 0.9.2
 CPU num => 4
...

安装graphviz

cd graphviz-2.38.0/
#后面参数是要确保安装了libphp才行哦【没安装的 brew install linpng 就可】
./configure --with-png=yes
make
sudo make install

测试一下了

在之前下载的xhprof文件夹里面,找到xhprof_html,xhprof_lib、sample三个文件夹,那这三个文件夹放到你可以访问到得地方去,然后通过连接先访问以下http://xxxx/sample/sample.php,在访问以下http://xxxx/xhprof_html/,就会看到有一条记录,点击后就可以看到分析结果页面,通过点击 View Full CallGraph链接到图形报表的页面。

如何使用

假设你现在要看看看自己做的一个网站的首页性能数据,那么你要找到这个网站的首页入口文件,在核心文件加载之前和之后分别加上xhprof的性能测试代码

#开启,具体参数说明可以查看官方文档
xhprof_enable(XHPROF_FLAGS_NO_BUILTINS | XHPROF_FLAGS_CPU | XHPROF_FLAGS_MEMORY);
#核心文件的执行
...
require 'index.php'
...
#关闭
$xhprof_data = xhprof_disable();
#这里的路径根据自己的站点来配置
$XHPROF_ROOT = realpath(dirname(__FILE__) .'/');
include_once $XHPROF_ROOT . "/xhprof_lib/utils/xhprof_lib.php";
include_once $XHPROF_ROOT . "/xhprof_lib/utils/xhprof_runs.php";
$xhprof_runs = new XHProfRuns_Default();
$run_id = $xhprof_runs->save_run($xhprof_data, "xhprof");
#这里打印出本次测试的id,方便到报表列表页面【http://xxxx/xhprof_html/】去通过对应的id找到对应的结果
var_dump($run_id);

希望本文所述对大家PHP程序设计有所帮助。

PHP 相关文章推荐
一个取得文件扩展名的函数
Oct 09 PHP
PHP 程序员的调试技术小结
Nov 15 PHP
PHP FOR MYSQL 代码生成助手(根据Mysql里的字段自动生成类文件的)
Jul 23 PHP
PHP编程中的常见漏洞和代码实例
Aug 06 PHP
Smarty中常用变量操作符汇总
Oct 27 PHP
php实现用于删除整个目录的递归函数
Mar 16 PHP
Laravel最佳分割路由文件(routes.php)的方式
Aug 04 PHP
php 反斜杠处理函数addslashes()和stripslashes()实例详解
Dec 25 PHP
什么是PHP7中的孤儿进程与僵尸进程
Apr 14 PHP
TP5(thinkPHP5框架)基于bootstrap实现的单图上传插件用法示例
May 29 PHP
PHP设计模式概论【概念、分类、原则等】
May 01 PHP
PHP ob缓存以及ob函数原理实例解析
Nov 13 PHP
PHP使用curl_multi实现并发请求的方法示例
Apr 29 #PHP
PHP实现转盘抽奖算法分享
Apr 15 #PHP
PHP cURL获取微信公众号access_token的实例
Apr 28 #PHP
详解php与ethereum客户端交互
Apr 28 #PHP
360搜索引擎自动收录php改写方案
Apr 28 #PHP
PHP使用Curl实现模拟登录及抓取数据功能示例
Apr 27 #PHP
PHP获取文件扩展名的常用方法小结【五种方式】
Apr 27 #PHP
You might like
php setcookie函数的参数说明及其用法
2014/04/20 PHP
深入理解PHP类的自动载入机制
2016/09/16 PHP
PHP接口并发测试的方法(推荐)
2016/12/15 PHP
PHP脚本自动识别验证码查询汽车违章
2016/12/20 PHP
PHP PDOStatement::nextRowset讲解
2019/02/01 PHP
javascript中String类的subString()方法和slice()方法
2011/05/24 Javascript
基于js中的原型、继承的一些想法
2016/08/10 Javascript
AngularJS指令中的绑定策略实例分析
2016/12/14 Javascript
js实现日期显示的一些操作(实例讲解)
2017/07/27 Javascript
Js利用Canvas实现图片压缩功能
2017/09/13 Javascript
详谈commonjs模块与es6模块的区别
2017/10/18 Javascript
express默认日志组件morgan的方法
2018/04/05 Javascript
浅谈ng-zorro使用心得
2018/12/03 Javascript
layui使用及简单的三级联动实现教程
2020/12/01 Javascript
MySQLdb ImportError: libmysqlclient.so.18解决方法
2014/08/21 Python
Python获取电脑硬件信息及状态的实现方法
2014/08/29 Python
浅析Python中的多重继承
2015/04/28 Python
Python排序搜索基本算法之冒泡排序实例分析
2017/12/09 Python
python的dataframe和matrix的互换方法
2018/04/11 Python
Python 隐藏输入密码时屏幕回显的实例
2019/02/19 Python
pandas 数据结构之Series的使用方法
2019/06/21 Python
Python面向对象原理与基础语法详解
2020/01/02 Python
基于python的docx模块处理word和WPS的docx格式文件方式
2020/02/13 Python
解决pycharm导入本地py文件时,模块下方出现红色波浪线的问题
2020/06/01 Python
如何从csv文件构建Tensorflow的数据集
2020/09/21 Python
python gui开发——制作抖音无水印视频下载工具(附源码)
2021/02/07 Python
澳大利亚手表品牌:Time IV Change
2018/10/06 全球购物
CNC数控操作工岗位职责
2013/11/19 职场文书
公司面试感谢信
2014/02/01 职场文书
业务内勤岗位职责
2014/04/30 职场文书
作风建设演讲稿
2014/05/23 职场文书
教师演讲稿开场白
2014/08/25 职场文书
受资助学生感谢信
2015/01/21 职场文书
公务员个人年终总结
2015/02/12 职场文书
同学聚会通知书
2015/04/20 职场文书
合同审查法律意见书
2015/06/04 职场文书