linux系统安装xhprof,xhprof扩展安装与使用

一、xhprof扩展安装步骤

xhprof是PHP的一个扩展,最好也直接安装上graphviz图形绘制工具(用于xhprof分析结果以直观的图形方式显示),废话不多说,直奔正题。

1、安装

PHP5版本的安装

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

tar -zxvf xhprof-0.9.4.tgz

cd xhprof-0.9.4

cd extension/

phpize

./configure

make

make install

PHP7版本的安装

unzip xhprof-php7.zip

cd xhprof-php7/extension/

phpize

./configure --with-php-config=/usr/local/php/bin/php-config

make

make install

2、修改php.ini配置文件

在php.ini配置文件中追加下面配置,并创建目录/home/wwwroot/default/xhprof_data

[xhprof]

extension = xhprof.so

// xhprof分析结果文件存放根目录

xhprof.output_dir = /home/wwwroot/default/xhprof_data

3、添加一个环境变量XHPROF_ROOT_PATH

为了后期每个项目都能使用xhprof来进行性能分析,建议给PHP加一个环境变量,这样之后,在任何项目代码里都可以很方便的调用xhprof来分析性能瓶颈,请执行如下操作:

vim /usr/local/php/etc/php-fpm.conf

env[XHPROF_ROOT_PATH]=/usr/local/php/include/xhprof/

4、将xhprof核心源代码复制到上述XHPROF_ROOT_PATH环境变量所指定的目录下

cp -r xhprof_lib /usr/local/php/include/xhprof/xhprof_lib

5、将下面两个目录复制到xhprof_data的同级目录下(最好都放到web根目录下)

查看分析结果文件有用,如下图所示:

5b0c10b09411466d64414eb74bb84aec.png

//执行

cp -r xhprof_html /home/wwwroot/default/xhprof_html

cp -r xhprof_lib /home/wwwroot/default/xhprof_lib

//改变xhprof_data目录拥有者,为了浏览器访问时能在xhprof_data目录下写入文件

chown -R www:www xhprof_data

6、访问xhprof根目录

配置demo.com域名根目录为/home/wwwroot/default/,则可访问如下链接查看xhprof结果分析根目录http://demo.com/xhprof_data/,如下图所示:

c9fb9eb1abe11af834792b806edd5608.png

7、形象化的查看分析结果

安装图形绘制工具,后面的分析结果可以通过该工具以图形显示,更直观

执行安装命令:yum install graphviz

二、xhprof的使用

1、xhprof性能分析小demo

下面写的三种方式实现阶乘的代码

xhprof_enable(XHPROF_FLAGS_CPU | XHPROF_FLAGS_MEMORY);

$n = 5;

echo jc($n);

echo '
';

echo jc($n);

echo '
';

echo jc($n);

echo '
';

function jc($n){

if($n == 1){

return 1;

}

return $n * jc($n-1);

}

function jc2($n){

$m = 1;

for($i=1; $i<=$n; $i++){

$m = $m * $i;

}

return $m;

}

function jc3($n){

$arr = [];

$arr[1] = 1;

for($i = 2; $i<=$n; $i++){

$arr[$i] = $i * $arr[$i-1];

}

return $arr[$n];

}

$data = xhprof_disable();

//$_SERVER['XHPROF_ROOT_PATH'] 这就是第三步添加的那个环境变量

include_once $_SERVER['XHPROF_ROOT_PATH'] . "xhprof_lib/utils/xhprof_lib.php";

include_once $_SERVER['XHPROF_ROOT_PATH'] . "xhprof_lib/utils/xhprof_runs.php";

$x = new XHProfRuns_Default();

//拼接文件名

$xhprofFilename = date('Ymd_His');

//print_r($data);die;//此处的打印数据看起来非常不直观,所以需要安装yum install graphviz 图形化界面显示,更直观

$x->save_run($data, $xhprofFilename);

上述小demo执行后,会在xhprof_data目录下生成一个分析结果保存文件,网页端访问结果文件,如下图:

4fe38d614556395d95c40ca26b39ff3c.png

47b5e2a6412e33bb234ea8c9b45c47c6.png

当我在点[View Full Callgraph]查看图形分析界面时,问题出现了,如下图:

90a4aa67138a4354e838d5c0bc3d56cf.png

好在网上查到原因是,php配置文件中有个disable_functions禁用函数列表,把里面的proc_open去掉即可。

图形分析结果显示如下

bd258f0fcdce38ca94a1c1f34d62c4c4.png

2、实际项目中该如何引入xhprof

请参考如下截图所示引入思路(在项目控制器基类构造方法和析构方法里做手脚),思路技巧仅供学习参考,如下图:

53c14cddce01049e071a7c6265c8c357.png

下面是我在项目(以Yii2为框架)下引入xhprof代码一览

namespace backend\component;

use Yii;

use common\component\baseController;

class backendBaseController extends baseController

{

public $layout = "/content";

public $enableCsrfValidation = false;

public static $profiling = 0;

public function init(){

parent::init();

self::$profiling = 1;// !(mt_rand() % 9);

if  (self::$profiling) {

xhprof_enable(XHPROF_FLAGS_CPU | XHPROF_FLAGS_MEMORY);

}

}

public function __destruct()

{

if(self::$profiling){

$data = xhprof_disable();

//$_SERVER['XHPROF_ROOT_PATH'] 该环境变量由第3步得来

include_once $_SERVER['XHPROF_ROOT_PATH'] . "/xhprof_lib/utils/xhprof_lib.php";

include_once $_SERVER['XHPROF_ROOT_PATH'] . "/xhprof_lib/utils/xhprof_runs.php";

$x = new XHProfRuns_Default();

//当前路由

$routeName = Yii::$app->requestedRoute;

//路由为空,则说明是首页

if (empty($routeName)){

$routeName = Yii::$app->defaultRoute;

}

//拼接xhprof分析结果保存文件名

$xhprofFilename = str_replace('/', '_', $routeName).'_'.date('Ymd_His');

$x->save_run($data, $xhprofFilename);

}

}

}

总结

xhprof是一个分析PHP代码性能瓶颈,提高PHP代码效率的有利工具,通过xhprof,可以看到代码慢在哪里,哪里还有优化的空间等等。

最后分享一个关于xhprof不错的资料,可以到Linux公社资源站下载:

------------------------------------------分割线------------------------------------------

具体下载目录在 /2018年资料/8月/28日/xhprof扩展安装与使用/

------------------------------------------分割线------------------------------------------

0b1331709591d260c1c78e86d0c51c18.png

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值