XHProf是一个分层PHP性能分析工具。
XHProf是一个分层PHP性能分析工具。它报告函数级别的请求次数和各类指标,包括阻塞时间,CPU时间和内存使用状况。一个函数的开销,可细分红调用者和被调用者的开销,XHProf数据收集阶段,它记录调用次数的追踪和包容性的指标弧在动态callgraph的一个程序。它独有的数据计算的报告/后处理阶段。在数据收集时,XHProfd经过检测循环来处理递归的函数调用,并经过给递归调用中每一个深度的调用一个有用的命名来避开死循环。XHProf分析报告有助于理解被执行的代码的结构,它有一个简单的HTML的用户界面( PHP写成的)。基于浏览器的性能分析用户界面能更容易查看,或是与同行们分享成果。也能绘制调用关系图。(来自百度百科)php
个人PHP版本是PHP7:html
而xhprof支持PHP7的库请在longxinH-xhprof查看。nginx
备注:我以前在phacility克隆的,不过安装失败,缘由就是个人PHP版本是PHP7,而phacility版本的并不支持。(采坑呢~~)git
当作一个php项目!clone别人php代码放哪一个目录你本身定
1.编译安装github
cd /Users/birjemin/Developer/Php git clone https://github.com/longxinH/xhprof cd xhprof/extension phpize ./configure make make install
2.配置文件vim
cd /usr/local/etc/php/7.0/conf.d vim ext-xhprof.ini
添加内容(这个就是编译成功以后的路径,见上图)浏览器
[xhprof] extension="/usr/local/Cellar/php70/7.0.14_7/lib/php/extensions/no-debug-non-zts-20151012/xhprof.so"
3.重启php-fpm(视我的重启方式而定,个人重启方式是这样的)bash
cd /usr/local/etc/php/7.0/ sudo killall php-fpm sudo /usr/local/Cellar/php70/7.0.14_7/sbin/php-fpm -D
4.查看是否安装成功php7
恭喜安装成功!app
1.若是使用呢?两种方法,第一种就是把xhprof_lib.php和xhprof_runs.php拷贝到项目中,第二种就是用绝对路径引入这两个文件,推荐第一种,这样别人clone的你的项目,不须要作啥。
2.创建两个开启函数(isDev()是判断本地环境的意思,请视状况删除)
function enableXhprof() { isDev() && xhprof_enable(0, []); }
function disableXhprof() { if (isDev()) { $xhprof_data = xhprof_disable(); include_once app_path() . "/xhprof_lib.php"; include_once app_path() . "/xhprof_runs.php"; $xhprof_runs = new \XHProfRuns_Default(); $run_id = $xhprof_runs->save_run($xhprof_data, "xhprof_foo"); #echo $run_id; } }
3.能够在须要监听的接口中代码片断前面加上enableXhprof(),后面加上disableXhprof()就行了。接下来就能够分析这段代码了。(请确保这两个函数全局访问)
4.将克隆的xprof配置虚拟主机,这个和你的项目同样的,就把xprof也当作一个项目,配置成浏览器可访问。好比个人配置:
server { listen 80; server_name local.xhprof.com; access_log logs/xhprof.access.log main; autoindex on; location / { root /Users/birjemin/Developer/Php/xhprof; index index.html index.htm index.php; try_files $uri $uri/ /index.php?$query_string; } location ~ \.php$ { root /Users/birjemin/Developer/Php/xhprof; fastcgi_pass 127.0.0.1:9000; fastcgi_index index.php; fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name; fastcgi_intercept_errors on; include fastcgi_params; } }
5.重启nginx,浏览器访问local.xhprof.com看看能不能访问(没有目录??你是否是浏览器没法访问目录??权限没开。。本身配置一下)
6.在postman或者浏览器访问接口,转啊转,好了以后就能够去http://local.xhprof.com/xhprof_html/
查看了。(图我就不截了。。下次讲一下xgui的使用)
1.php -v的版本和phpinfo()的版本不一致,以下图:
解决方法:更改php cli的默认版本
vim .bash_profile
# PHP -v export PATH="/usr/local/Cellar/php70/7.0.14_7/bin:$PATH"
source .bash_profile
2.编译成功,可是php -m 没有 xhprof。
xhprof支持PHP7的库请在longxinH-xhprof查看!!!!
全程经历了2.5h吧~~~不过文章也写了2.5h。哈哈哈哈~这个东西和xdebug不同的,这个是分析性能瓶颈的,可让你优化代码。xdebug主要用于调试,我下次写一个xdebug安装的过程。