原文:https://gold.xitu.io/post/5860d23f128fe10069e1cfbf

XHPROF:Facebook 开源的轻量级PHP性能分析工具。

它报告函数级别的请求次数和各种指标,包括阻塞时间,CPU时间和内存使用情况。

XHProf 分析报告有助于理解被执行的代码的结构。

它有一个简单的HTML的用户界面( PHP写成的)。

基于浏览器的性能分析用户界面能更容易查看,或是与同行们分享成果。

也能绘制调用关系图。

XHPROF 与 Xdebug 区别

Xdebug 是一个开放源代码的PHP程序调试器(即一个Debug工具)。

对于本地开发环境来说,进行性能分析 Xdebug 是够用了。

但如果是线上环境的话,Xdebug 消耗较大,配置也不够灵活。

如何安装 XHPROF ?

//源码安装
cd /usr/local/src
wget http://pecl.php.net/get/xhprof-0.9.4.tgz
tar zxvf xhprof-0.9.4.tgz
cd xhprof-0.9.4/extension/
/usr/local/php/bin/phpize
./configure --with-php-config=/usr/local/php/bin/php-config
make
make install //在 php.ini 末尾新增
[xhprof] extension = xhprof.so xhprof.output_dir = 自定义文件夹(/tmp/xhprof_log)
// /tmp/xhprof_log 必须存在且有写入权限 //重启环境 //代码中查看 phpinfo 是否包含 xhprof。 //一切顺利的话,那么 xhprof 安装成功。

如何配置 XHPROF?

//比如项目地址:local.test_xhprof.com
//在项目入口文件中新增一下代码(CI框架为例)
xhprof_enable(XHPROF_FLAGS_NO_BUILTINS +
XHPROF_FLAGS_CPU +
XHPROF_FLAGS_MEMORY); register_shutdown_function(function(){
$data = xhprof_disable(); //返回运行数据
//xhprof_lib 在下载的包里存在这个目录,记得将目录包含到运行的php代码中
include '/home/www/mi/xhprof/xhprof_lib/utils/xhprof_lib.php';
include '/home/www/mi/xhprof/xhprof_lib/utils/xhprof_runs.php';
$objXhprofRun = new XHProfRuns_Default();
$objXhprofRun->save_run($data, "test"); //test 表示文件后缀
}); //一切顺利的话,那么代码安装成功。 //访问:local.test_xhprof.com,应该在 /tmp/xhprof_log 存在日志文件。

如何 UI 展示?

//将 xhprof_html、xhprof_lib 拷贝到虚拟目录中
cd /usr/local/src
cp xhprof-0.9.4/xhprof_html /home/www/mi/xhprof/xhprof_html
cp xhprof-0.9.4/xhprof_lib /home/www/mi/xhprof/xhprof_lib

配置虚拟主机(local.xhprof.com)

local.xhprof.com 指向 /home/www/mi/xhprof/ 即可。

访问:local.xhprof.com/xhprof_html 会显示日志文件。

如下图:

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

点击日志文件显示下图。

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

点击 [View Full Callgraph] 会显示调用关系图。

在生成图的时候需要服务器装一个插件:graphviz。

cd /usr/local/src
wget http://www.graphviz.org/pub/graphviz/stable/SOURCES/graphviz-2.24.0.tar.gz
tar zxvf graphviz-2.24.0.tar.gz
cd graphviz-2.24.0
./configure
make
make install //一切顺利的话,那么 graphviz 安装成功。

如果点击 [View Full Callgraph] 依旧无法打开。

报错:failed to execute cmd " dot -Tpng"

表示:php.ini 中一些执行函数禁用了。

在 php.ini 中 去掉 disable_functions 中的如下函数
system
shell_exec
proc_open
proc_get_status

PHP 重启一下。

一切顺利的话,应该不会报错了,就可以看到高大上的效果图啦。

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

点击局部,可以看到大图。

以上,大家可以看到 函数级别的请求次数和各种指标,包括阻塞时间,CPU时间和内存使用情况。

如何更好的UI展示?

可能大家有一些疑问:

  1. 是否能有更好的UI展示?
  2. 当服务器上有多个站点的时候,是否配置一次即可?

接下来给大家介绍:xhprof gui

xhprof gui : 一个xhprof的一个ui展现。

使 xhprof 界面更漂亮,功能更强大。

  • 友好的界面
  • 数据库存储(mysql)
  • 支持按请求百分比执行 xhprof 优化。
  • 降低服务器负载。

如何配置 xhprof gui

源码地址:https://github.com/preinheimer/xhprof

下载后存放到:xhprof_gui 文件中。

配置虚拟主机(local.xhprofgui.com)

local.xhprofgui.com 指向 /home/www/mi/xhprof_gui/ 即可。

第一步,需要将 xhprof_gui/xhprof_lib/config.sample.php 重命名 为 config.php。

第二步,根据 config.php 中数据库变量(dbuser、dbpass、dbname),配置一个数据库。

第三步,将 config.php 中 doprofile 设置为 true。

第三步,创建一张表。

//源代码:xhprof_lib/utils/xhprof_runs.php
CREATE TABLE `details` (
`id` char(17) NOT NULL,
`url` varchar(255) default NULL,
`c_url` varchar(255) default NULL,
`timestamp` timestamp NOT NULL default CURRENT_TIMESTAMP on update CURRENT_TIMESTAMP,
`server name` varchar(64) default NULL,
`perfdata` MEDIUMBLOB,
`type` tinyint(4) default NULL,
`cookie` BLOB,
`post` BLOB,
`get` BLOB,
`pmu` int(11) unsigned default NULL,
`wt` int(11) unsigned default NULL,
`cpu` int(11) unsigned default NULL,
`server_id` char(3) NOT NULL default 't11',
`aggregateCalls_include` varchar(255) DEFAULT NULL,
PRIMARY KEY (`id`),
KEY `url` (`url`),
KEY `c_url` (`c_url`),
KEY `cpu` (`cpu`),
KEY `wt` (`wt`),
KEY `pmu` (`pmu`),
KEY `timestamp` (`timestamp`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8;

如果是 Nginx 服务器 新增配置:

fastcgi_param PHP_VALUE "auto_prepend_file=/home/www/mi/xhprof_gui/external/header.php";

如果是 Apache 服务器:

php_admin_value auto_prepend_file "/home/www/mi/xhprof_gui/external/header.php"

配置到这里,可以运行下。

简单说明下:

如果你配置在公共的配置文件中,那么表示站点上所有的域名访问都会进行日志记录。

如果你配置在单个域名的配置文件中,表示只有访问当前域名的时候回进入日志记录。

例如单个域名为:local.xh.test.com

如果报错,可以调试下 header.php。

以上配置,存储使用的是Mysql。

存储也可以使用MongoDB,大家可以研究下 ~

如果看到效果?

访问 local.xh.test.com,记录日志。

访问 local.xhprofgui.com,查看效果。

效果图,如下:

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

我本地为 nginx 环境,已经配置成功。

PHP 性能追踪及分析工具(XHPROF)的更多相关文章

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

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

  2. 转:使用xhprof进行线上PHP性能追踪及分析

    原文来自于:http://avnpc.com/pages/profiler-php-performance-online-by-xhprof 原创作者:AlloVince 之前一直使用基于Xdebug ...

  3. 如何使用工具进行线上 PHP 性能追踪及分析?

    工作了一两年的 PHPer 大概都多多少少知道一些性能分析的工具,比如 Xdebug.xhprof.New Relic .OneAPM.使用基于 Xdebug 进行 PHP 的性能分析,对于本地开发环 ...

  4. golang 性能调优分析工具 pprof(下)

    golang 性能调优分析工具 pprof(上)篇, 这是下篇. 四.net/http/pprof 4.1 代码例子 1 go version go1.13.9 把上面的程序例子稍微改动下,命名为 d ...

  5. golang 性能调优分析工具 pprof (上)

    一.golang 程序性能调优 在 golang 程序中,有哪些内容需要调试优化? 一般常规内容: cpu:程序对cpu的使用情况 - 使用时长,占比等 内存:程序对cpu的使用情况 - 使用时长,占 ...

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

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

  7. 如何在本地配置php分析工具xhprof

    测试环境: linuxMint + nginx1.4.6+mysql5.5+php5.5 什么是xhprof? XHProf是一个分层PHP性能分析工具.它报告函数级别的请求次数和各种指标,包括阻塞时 ...

  8. linux性能评估与分析工具---CPU篇

    一. uptime root@calm:~# uptime :: up days, :, user, load average: 0.04, 0.09, 0.04 这里主要关注load average ...

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

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

随机推荐

  1. java工程开发之图形化界面之(第四课)

    本节中,我们将创建一个小应用程序,它使用循环生成其图案.我们将使用if语句和setColor方法.同时我们将介绍drawString方法,并使用它在小应用程序窗口中写出文本. 下面的小应用程序是显示一 ...

  2. Using Sphinx to index CNS database

    1, look at the sphinx.person.address.conf to see how to configure the conf file2, index the database ...

  3. 注意:MainActivity的oncreate方法里不要再inflate布局了(MainActivity里的点击事件无响应)

    activity_main已经通过setContentView(R.layout.activity_main);设置给MainActivity, 不要再inflate出新布局,然后findviewby ...

  4. Linux 查询程序安装路径 是否安装

    rpm -ql httpd #[搜索rpm包]--list所有文件安装目录 rpm -q mysql  //查询程序是否安装 关于rpm详细用法 参考 http://www.cnblogs.com/x ...

  5. access restriction

    一.既然存在访问规则,那么修改访问规则即可.打开项目的Build Path Configuration页面,打开报错的JAR包,选中Access rules条目,选择右侧的编辑按钮,添加一个访问规则即 ...

  6. 鉴客 C# 抓取页面(带认证)

    1. [代码][C#]代码     01 HttpWebRequest req = (HttpWebRequest)HttpWebRequest.Create(""); 02 re ...

  7. MusiCode 批量下载指定歌手的所有专辑(已解除验证码限制)

    一直想把喜欢的歌手的专辑全都归类并下载下来,由于那专辑数量实在太多了,再加上最近开始学习python,就想着何不用python写个脚本把下载过程自动化呢?所以就花了点时间写了这么个东西,分享给有需要的 ...

  8. HDU 1251 统计难题(字典树计算前缀数量)

    字典树应用,每个节点上对应的cnt是以它为前缀的单词的数量 #include<stdio.h> #include<string.h> struct trie { int cnt ...

  9. hrbustoj 2130 一笔画(状态压缩)

    基础状态压缩 转移方程为 dp[j][i] = min(dp[j][i],dp[k][i^(1<<j)] + dis[k][j]); #include<iostream> #i ...

  10. [其他]volatile 关键字

    用  volatile 关键字修饰函数 的作用是 告诉编译器该函数不会返回 , 让编译器能产生更好的代码 另外也能避免一些假警告信息,如未初始化的变量等