什么是 Xhprof?
XHProf是facebook 开发的一个测试php性能的扩展,本文记录了在PHP应用中使用XHProf对PHP进行性能优化,查找性能瓶颈的方法。

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

XHProf分析报告有助于理解被执行的代码的结构,它有一个简单的HTML的用户界面( PHP写成的)。

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

也能绘制调用关系图。

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

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

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

下载安装Xhprof

直接从github下载zip压缩包,地址:https://github.com/longxinH/xhprof

# unzip xhprof-master.zip
# cd xhprof-master
# cd extension/
# phpize
# ./configure --with-php-config=/usr/local/php/bin/php-config --enable-xhporf
# make && make install

 # vim /usr/local/php/etc/php.ini  //编辑php.ini,添加如下代码
extension=/usr/local/php/lib/php/extensions/no-debug-non-zts-/xhprof.so
# service php-fpm restart  //重启
# php -m | grep xhprof //命令查看是否安装xhprof扩展

配置到项目中进行性能分析

我在同测试项目的Linux服务器里搭建了虚拟主机,把xhprof定义了一个域名访问

我这使用的Nginx配置的虚拟主机,域名为:http://myxhprof.com,在你们搭建完成之后,可以试着访问一下sample.php文件,这是一个小Demo,有开始和结束为止,文件中有注释。

我所在的测试项目所用框架是tp,进入解压包目录下中的xhprof_lib目录,把utils目录拷贝到了项目目录下,我放到了Lib目录下,然后在common的公共函数文件中写入一个方法,代码如下,当然这个函数我简单的定义了一下,如果您在实际生产环境中分析的话,可以专门定义一个区分线上线上的标识~

//common文件自定义函数
function xhprof ()
{
$xhprof_data = xhprof_disable();
include_once "/data/wwwroot/default/gaiban/Lib/utils/xhprof_lib.php";
include_once "/data/wwwroot/default/gaiban/Lib/utils/xhprof_runs.php";
$xhprof_runs = new \XHProfRuns_Default();
$run_id = $xhprof_runs->save_run($xhprof_data, "xhprof_foo"); echo '开始性能分析地址:<a href="http://myxhprof.com/index.php?run='.$run_id .'&source=xhprof_foo" target="_blank">点击分析</a>';
}
//测试项目访问的方法
<?php
class Test {
public function index()
{
//-------------------------------------------------------------程序运行开始函数位置
xhprof_enable();//---------------------------------------------程序运行开始函数位置
//-------------------------------------------------------------程序运行开始函数位置
$Rand_hot = $this->Rand_hot_article();
$Hot_list = $this->hot_acticle();
$links = $this->links();
$this->assign('links',$links);
$this->gg = $this->gonggao_merge();
$TagList = $this->Tags();
$Newlist_Page = $this->New_Article();
$Newlist = $Newlist_Page['list'];
$Page = $Newlist_Page['page'];
//-------------------------------------------------------------程序运行结束函数位置
xhprof();//------------这里是common自定义的函数位置--------------程序运行结束函数位置
//-------------------------------------------------------------程序运行结束函数位置
$this->assign('Hot_list',$Hot_list);
$this->assign('Rand_list',$Rand_hot);
$this->assign('NewLIST',$Newlist);
$this->assign('Page',$Page);
$this->assign('TagList',$TagList);
$this->display();
}

然后访问项目

形象化的查看分析结果

使用xhprof_disable完成性能分析并且获取到分析结果之后,我们通常不会直接输出结果,因为这样的结果是以数组形式组织的,看起来并不直观,幸运的是,xhprof提供了基于web的图形界面对分析结果进行查看。

在使用之前,请先确保服务器安装了graphviz工具,否则在生成监控图表的时候回出现以下错误:

failed to execute cmd: " dot -Tpng". stderr: `sh: dot: command not found '

解决办法直接yum安装:

#  yum install graphviz

如果安装好了graphviz,仍然出现”failed to execute cmd”,检查下服务器上的php.ini中disable_functions这项是不是限制了proc_open,因为在xhprof_lib/utils/callgraph_utils.php的xhprof_generate_image_by_dot中使用了proc_open函数,或者设置“disable_functions = “ 即可,一般没有必要在php.ini中关闭函数使用,人为修炼代码技术即可。

解决完错误,再次请求,出现下面效果图。注意到中间的[View Full Callgraph]链接,通过该链接我们可以看到图形化的分析结果。

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

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

图中红色的部分为性能比较低,耗时比较长的部分,我们可以根据根据哪些函数被标记为红色对系统的代码进行优化

Centos下给PHP7添加Xhprof性能分析的更多相关文章

  1. PHP拓展 - xhprof性能分析工具

    Windows安装 参考:https://www.cnblogs.com/buexplain/p/4821619.html dll文件下载:https://windows.php.net/downlo ...

  2. centos下python中添加easygui模块

    前提:python中要集成Tkinter,Tkinter模块("Tk 接口")是Python的标准Tk GUI工具包的接口.Tk和Tkinter可以在大多数的Unix平台下使用,同 ...

  3. 使用 xhprof 进行 php 的性能分析

    基于本机环境(php7,macos) 1.xhprof 扩展 php7 下安装 xhprof 扩展: git clone https://github.com/longxinH/xhprof cd x ...

  4. 记一次docker问题定位(perf,iostat等性能分析)

    背景 最近参与的项目是基于 OpenStack 提供容器管理能力,丰富公司 IaaS 平台的能力.日常主要工作就是在开源的 novadocker 项目(开源社区已停止开发)基础上进行增强,与公司的其他 ...

  5. php性能分析利器:xhprof

    xhprof是facebook团队开发的用于研究php性能的扩展,并且提供了图形化的界面展示性能参数和过程.对于各种php的项目的性能瓶颈研究有一定帮助,值得一用. 我在上一篇<Dockerfi ...

  6. PHP 性能分析第一篇: Xhprof & Xhgui 介绍

    [前言]这是国外知名博主 Davey Shafik所撰写的 PHP 应用性能分析系列的第一篇,阅读第二篇可深入了解 xhgui,第三篇则关注于性能调优实践. 什么是性能分析? 性能分析是衡量应用程序在 ...

  7. PHP性能分析——xhprof(window 安装xhporf)

    1 下载xhprof的php扩展 因为官方的xhprof不支持php7,所以采用tideways版本的xhprof 下载地址:windows版tideways_xhprof 将windows版的dll ...

  8. PHP 性能分析第一篇: Intro to Xhprof & Xhgui

    [前言]这是国外知名博主 Davey Shafik所撰写的 PHP 应用性能分析系列的第一篇,阅读第二篇可深入了解 xhgui,第三篇则关注于性能调优实践. 原文链接如下: https://blog. ...

  9. CentOS下性能监测工具 dstat

    原文链接:http://www.bkjia.com/Linuxjc/935113.html 参考链接:https://linux.cn/article-3215-1.html,http://lhfli ...

随机推荐

  1. CentOS 6.5 配置IP地址的三种方法

    1.自动获取IP地址虚拟机使用桥接模式,相当于连接到物理机的网络里,物理机网络有DHCP服务器自动分配IP地址.#dhclient 自动获取ip地址命令#ifconfig 查询系统里网卡信息,ip地址 ...

  2. 40 个顶级 jQuery 图片、内容滑块和幻灯片

    在这个快速发展的网络世界中,我们使用图片.内容滑块和幻灯片来给网站实现良好.有吸引力的外观.你可以吸引浏览者借助图像滑块让网站更加具有活力.使用 JavaScript 可以轻松实现轻量级的图片和内容滑 ...

  3. Http协议原理解析第一篇

    一:http的由来: OSI模型把网络通信分成七层:物理层.数据链路层.网络层.传输层.会话层.表示层和应用层,对于开发网络应用人员来说,一般把网络分成五层,这样比较容易理解.这五层为:物理层.数据链 ...

  4. 【BZOJ2424】[HAOI2010]订货 最小费用流

    [BZOJ2424][HAOI2010]订货 Description 某公司估计市场在第i个月对某产品的需求量为Ui,已知在第i月该产品的订货单价为di,上个月月底未销完的单位产品要付存贮费用m,假定 ...

  5. vue+node+mongoDB火车票H5(七)-- nodejs 爬12306查票接口

    菜鸟一枚,业余一直想做个火车票查票的H5,前端页面什么的已经写好了,node+mongoDB 也写了一个车站的接口,但 接下来的爬12306获取车次信息数据一直卡住,网上的爬12306的大部分是pyt ...

  6. Java switch 详解

    switch 语句由一个控制表达式和多个case标签组成. switch 控制表达式支持的类型有byte.short.char.int.enum(Java 5).String(Java 7). swi ...

  7. Spoken English Practice(1、This is between you and me, Don't let it out. 2、Don't let your dreams be dreams, no matter how hard it gets, say to yourself, I'm going to make it.)

    绿色:连读:                  红色:略读:               蓝色:浊化:               橙色:弱读     下划线_为浊化 口语蜕变(2017/7/12) ...

  8. JS实现关闭当前子窗口,刷新父窗口及调用父窗口的方法

    一.js实现关闭当前子窗口,刷新父窗口 JS代码如下: <script> function refreshParent() {  window.opener.location.href = ...

  9. [iOS微博项目 - 3.6] - 获取未读消息

    github: https://github.com/hellovoidworld/HVWWeibo   A.获取登陆用户未读消息 1.需求 获取所有未读消息,包括新微博.私信.@.转发.关注等 把未 ...

  10. bootloader,kernel,initrc

    http://www.ibm.com/developerworks/cn/linux/l-k26initrd/index.html http://www.68idc.cn/help/server/li ...