一、安装:
扩展安装
$ /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): 函数运行消耗内存(不包括子函数)
二、试图
非常直观的查到代码瓶颈点,主要是粗线条,颜色越深特别是红色区域就是需要优化的地方。