性能测试定位php工具Xhprof

一、安装:

扩展安装

$ /Applications/MAMP/bin/php/php5.6.40/bin/phpize
$ ./configure --with-php-config=/Applications/MAMP/bin/php/php5.6.40/bin/php-config
make && make install

修改php.ini文件

[xhprof]
extension=ion=xhprof.so
xhprof.output_dir=/data/logs/xhprof

测试脚本编写

<?php

$XHPROF_ROOT = realpath(dirname(__FILE__));

require_once $XHPROF_ROOT . "/xhprof_lib/utils/xhprof_lib.php";
require_once $XHPROF_ROOT . "/xhprof_lib/utils/xhprof_runs.php";

//开启xhprof
# xhprof_enable(XHPROF_FLAGS_CPU + XHPROF_FLAGS_MEMORY);
 xhprof_enable(XHPROF_FLAGS_NO_BUILTINS | XHPROF_FLAGS_CPU | XHPROF_FLAGS_MEMORY);

//注册一个函数,当程序执行结束的时候去执行它。
register_shutdown_function(function () {
    //stop profiler
    $xhprof_data = xhprof_disable();

    //冲刷(flush)所有响应的数据给客户端
    if (function_exists('fastcgi_finish_request')) {
        fastcgi_finish_request();
    }

    $xhprof_runs = new XHProfRuns_Default();

    //save the run under a namespace "xhprof_foo"
    $run_id = $xhprof_runs->save_run($xhprof_data, "xhprof");

    echo '<a href="http://xhprof.test/index.php?run=' . $run_id . '&source=xhprof" target="_blank">性能分析</a>';
});

apache配置

修改配置

# 在 <Directory> 中追加如下内容
php_value auto_prepend_file "/Users/nilsir/code/opensources/xhprof/inject.php"

添加xhprof的站点

根目录为: /Users/nilsir/code/opensources/xhprof/xhprof_html

图形化配置

# mac
$ brew install libpng
$ brew install graphviz
# ubuntu
$ sudo apt-get install -y libpng-dev
$ sudo apt-get install -y graphviz
# centos
$ yum install -y libpng-devel
$ yum install -y graphviz

图形化配置bug修改

# vim /Users/nilsir/code/opensources/xhprof/xhprof_lib/utils/callgraph_utils.php
# 替换 $cmd = " dot -T".$type;为
$cmd = " export LD_LIBRARY_PATH=/usr/local/Cellar/graphviz/2.44.1/lib && /usr/local/Cellar/graphviz/2.44.1/bin/dot -T" .$type;

ngnix配置

server {
    listen 80;
    #server_name images.test *.images.test;

    server_name xhprof.test *.xhprof.test;
    charset utf-8;

    location / {
        add_header Access-Control-Allow-Origin *;
        add_header Access-Control-Allow-Methods 'GET, POST, OPTIONS';
        add_header Access-Control-Allow-Headers 'DNT,X-Mx-ReqToken,Keep-Alive,User-Agent,X-Requested-With,If-Modified-Since,Cache-Control,Content-Type,Authorization';

         if ($request_method = 'OPTIONS') {
             return 204;
         }
        proxy_pass http://172.0.0.0:116;    #先要开通116端口
    }

    location ~ /\.(?!well-known).* {
        deny all;
    }
}

二、xhprof报告怎么看

1. 调用堆栈表格

Calls/Calls %:  函数的调用次数,以及百分比。可以检测调用次数高的函数是否有必要

Incl.Wall Time(microsec) : 函数运行时间(包括子函数)

Excl.Wall Time(microsec) : 函数运行时间(不包括子函数), 这里可以倒序,优化消耗时间最高的函数

Incl.CPU(microsecs):函数运行CPU(包括子函数)

Excl.CPU(microsecs):函数运行CPU(不包括子函数)

Incl.MemUse(bytes) : 函数运行消耗内存(包括子函数)

Excl.MemUse(bytes):   函数运行消耗内存(不包括子函数)
 

二、试图

非常直观的查到代码瓶颈点,主要是粗线条,颜色越深特别是红色区域就是需要优化的地方。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

colleen_bu

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值