测试环境:

linuxMint + nginx1.4.6+mysql5.5+php5.5

什么是xhprof?

XHProf是一个分层PHP性能分析工具。它报告函数级别的请求次数和各种指标,包括阻塞时间,CPU时间和内存使用情况。一个函数的开销,可细分成调用者和被调用者的开销,XHProf数据收集阶段,它记录调用次数的追踪和包容性的指标弧在动态callgraph的一个程序。

一,如何安装?

1,下载最新的xhprof包

官网地址:https://pecl.php.net/package/xhprof

下载下来:

wget https://pecl.php.net/get/xhprof-0.9.4.tgz

解压:

tar -xvf xhprof-0.9..tgz

2,编译安装pecl扩展库

参考地址:http://php.net/manual/zh/install.pecl.phpize.php

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

编译成功后,在扩展库目录中会有一个xhprof.so文件

扩展库目录地址:/usr/lib/php5/20121212/

3,修改php配置文件

由于我的电脑用的是php-cgi,需要添加一个配置。

cd /etc/php5/cgi/conf.d

新建:xhprof.ini文件

extension=xhprof.so

4,重启php,重启php-cgi

重启php:

sudo service php5-fpm restart

重启php-cgi

kill - 17445

php-cgi -b 127.0.0.1:9000&

5,复制xhprof到网站根目录

比如我的根目录为:/data/webroot/

复制两个目录即可:

cp -r xhprof_html/ /data/webroot/
cp -r xhprof_lib/ /data/webroot/

6,查看本地环境是否正确安装了xhprof

新建文件:info.php

<?php
echo phpinfo();

如果能在页面中搜索到xhprof,表示已经正确安装了xhprof:

xhprof

xhprof    0.9.4
CPU num

二、如何使用?

xhprof使用比较简单。

在下载的目录里面有一个文件 examples/sample.php 文件

<?php                                                                                                                                                                        

function bar($x) {
if ($x > ) {
bar($x - );
}
} function foo() {
for ($idx = ; $idx < ; $idx++) {
bar($idx);
$x = strlen("abc");
}
} // start profiling
xhprof_enable(); // run program
foo(); // stop profiler
$xhprof_data = xhprof_disable(); // display raw xhprof data for the profiler run
print_r($xhprof_data); $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"; // 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://localhost/xhprof/index.php?run=$run_id&source=xhprof_foo\n".
"---------------\n";

 

在浏览器查看这个文件会显示下面的代码:

--------------- Assuming you have set up the http based UI for XHProf at some address, you can view run at http://localhost/xhprof/index.php?run=562614ece2e2d&source=xhprof_foo ---------------

这时访问:http://localhost/xhprof/index.php 会出现几个文件:

No XHProf runs specified in the URL.

Existing runs:

562614ece2e2d.xhprof_foo.xhprof -- ::
562614e0b76b2.xhprof_foo.xhprof -- ::
562614a33f6ec.xhprof_foo.xhprof -- ::
5626146be4aaf.xhprof_foo.xhprof -- ::
5626146324cdd.xhprof_foo.xhprof -- ::

点击进去一个:

http://localhost/xhprof/index.php?run=562614ece2e2d&source=xhprof_foo

点击[View Full Callgraph]  可能会报错

failed to execute cmd: " dot -Tpng". stderr: `sh: 1: dot: not found '

是因为没有安装图形化工具

sudo apt-get install graphviz

安装完后,再打开,就可以看到视图了。

名词:
. Inclusive Time :包括子函数所有执行时间。
. Exclusive Time/Self Time:函数执行本身花费的时间,不包括子树执行时间。
. Wall Time:花去了的时间或挂钟时间。
. CPU Time:用户耗的时间+内核耗的时间
.Inclusive CPU:包括子函数一起所占用的CPU
.Exclusive CPU:函数自身所占用的CPU

如何在本地配置php分析工具xhprof的更多相关文章

  1. MySQL慢日志查询全解析:从参数、配置到分析工具【转】

    转自: MySQL慢日志查询全解析:从参数.配置到分析工具 - MySQL - DBAplus社群——围绕数据库.大数据.PaaS云,运维圈最专注围绕“数据”的学习交流和专业社群http://dbap ...

  2. PHP性能追踪及分析工具xhprof的安装与使用

    对于本地开发环境来说,进行性能分析xdebug是够用了,但如果是线上环境的话,xdebug消耗较大,配置也不够灵活,因此线上环境建议使用xhprof进行PHP性能追踪及分析. 我们今天就简单介绍一下x ...

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

    一.前言 有用的东西还是记录下来吧,也方便以后的查询:这次记录一下xhprof的安装使用: xhprof是facebook开源出来的一个php轻量级的性能分析工具,跟Xdebug类似,但性能开销更低, ...

  4. PHP性能分析工具xhprof的安装使用与注意事项

    前言 xhprof由facebook开源出来的一个PHP性能监控工具,占用资源很少,甚至能够在生产环境中进行部署. 它可以结合graphviz使用,能够以图片的形式很直观的展示代码执行耗时. 下面主要 ...

  5. windows下安装php性能分析工具XHProf

    一.安装扩展 下载XHProf扩展:http://dev.freshsite.pl/php-extensions/xhprof.html 放入扩展文件:下载后解压出.dll文件,拷贝它到php的ext ...

  6. php性能分析工具xhprof

    安装方法: wget http://pecl.php.net/get/xhprof-0.9.x.tgz cp xhprof-0.9.x.tgz /home/www/xhprof.tgz tar zxv ...

  7. windows配置xhprof,PHP性能分析工具

    本来以为配置这么一个工具不会费很大的力气,后面发现完全不是. 一.小插曲 早上显示电脑不能显示虚拟目录下的所有域名,但是能打开localhost,数据库连接也不行了.这个问题纠缠了我一个上午.对了还有 ...

  8. PHP 性能追踪及分析工具(XHPROF)

    原文:https://gold.xitu.io/post/5860d23f128fe10069e1cfbf XHPROF:Facebook 开源的轻量级PHP性能分析工具. 它报告函数级别的请求次数和 ...

  9. 日志分析工具ELK配置详解

    日志分析工具ELK配置详解 一.ELK介绍 1.1 elasticsearch 1.1.1 elasticsearch介绍 ElasticSearch是一个基于Lucene的搜索服务器.它提供了一个分 ...

随机推荐

  1. 【BZOJ-1717】Milk Patterns产奶的模式 后缀数组

    1717: [Usaco2006 Dec]Milk Patterns 产奶的模式 Time Limit: 5 Sec  Memory Limit: 64 MBSubmit: 881  Solved:  ...

  2. Android成长日记-使用ViewFlipper实现屏幕切换动画效果

    (一) ViewFlipper介绍 Android系统自带的一个多页面管理控件,它可以实现子界面的自动切换 (二) 为ViewFlipper加入View 1. 静态导入:在Layout布局文件中直接导 ...

  3. Windows Sqlserver Automatic Log Audit Via C/C++

    catalog . 数据库日志审计产品 . Mysql日志审计 . SQLServer日志审计 1. 数据库日志审计产品 Relevant Link: http://enterprise.huawei ...

  4. RabbitMQ Exchange中的fanout类型

    fanout 多播 在之前都是使用direct直连类型的交换机,通过routingkey来决定把消息推到哪个queue中. 而fanout则是把拿到消息推到与之绑定的所有queue中. 分析业务,怎样 ...

  5. Sublime Text以及Package Control安装方法

    官方下载:Sublime Text 中国论坛:Sublime 论坛 Sublime Text 是一个代码编辑器,具有漂亮的用户界面和强大的功能,并且它还是一个跨平台的编辑器,同时支持Windows.L ...

  6. Ubuntu学习总结-08 Ubuntu运行Shell脚本报 shell /bin/bash^M: bad interpreter错误问题解决

    错误原因之一很有可能是运行的脚本文件是DOS格式的, 即每一行的行尾以\r\n来标识, 其ASCII码分别是0x0D, 0x0A.可以有很多种办法看这个文件是DOS格式的还是UNIX格式的, 还是MA ...

  7. MooseFs-分布式文件系统系列(二)之安装总结

    preface 上篇博客写了如何安装MFS,那么现在就说说经验总结把 安装方式有源码和yum安装,在官网地址:https://moosefs.com/download/centosfedorarhel ...

  8. SaltStack之无Master和多Master(九)

    SaltStack之无Master和多Master Masterless架构,无Master 实现方式: 1)关闭minion进程 2)修改配置文件 vi /etc/salt/minion file_ ...

  9. sql 中的运算符级别 如and or not

    写了这么多简单的sql,很多东西忘记得差不多了,差点连最基本sql运算符优先级都忘了.平时最常用到and or的优先级都忘了 and的优先级高于or的优先级 举个例子 select * from us ...

  10. Navicat 的使用(二)

    一,navicat如何写sql语句查询? 方法1:ctrl+q就会弹出一个sql输入窗口,就可以在里面写sql了.写完sql后,直接ctrl+r就执行sql了. 还有一点,写sql语句时,navica ...