php性能分析工具:xhprof

举报
仙士可 发表于 2023/06/21 16:47:49 2023/06/21
【摘要】 xhprof是php的一个性能分析扩展,它可以帮助我们查看php执行情况,有助于我们优化php的执行语句.安装xhprof的开源地址为:https://github.com/longxinH/xhprof版本下载地址:https://github.com/longxinH/xhprof/releases安装命令: wget https://github.com/longxinH/xhprof...

xhprof是php的一个性能分析扩展,它可以帮助我们查看php执行情况,有助于我们优化php的执行语句.

安装

xhprof的开源地址为:https://github.com/longxinH/xhprof

版本下载地址:https://github.com/longxinH/xhprof/releases

安装命令:

 wget https://github.com/longxinH/xhprof/archive/v2.1.0.tar.gz
 tar -zvxf v2.1.0.tar.gz
 cd xhprof-2.1.0/
 cd extension/
 phpize
 ./configure --with-php-config=/www/server/php/72/bin/php-config 
 make && make install
复制

在php.ini增加配置

[xhprof]
extension=xhprof.so;
xhprof.output_dir=/tmp/xhprof
复制

说明

./configure 不一定需要增加--with-php-config,只有当服务器有多个版本或者php-config没有在/usr/bin的时候才需要 xhprof的output_dir配置项需要可读可写权限,可以自己设定

使用

测试类引入:

还记得之前下载的源码吗?把里面的xhprof_lib目录复制出来,复制到项目目录,并且引入:

include_once '/home/tioncico/www/xhprof/xhprof_lib/utils/xhprof_lib.php';
include_once '/home/tioncico/www/xhprof/xhprof_lib/utils/xhprof_runs.php';
复制

开启性能分析:xhprof_enable函数

xhprof_enable(XHPROF_FLAGS_CPU|XHPROF_FLAGS_MEMORY|XHPROF_FLAGS_NO_BUILTINS);
//XHPROF_FLAGS_NO_BUILTINS (integer)
//使得跳过所有内置(内部)函数。
//XHPROF_FLAGS_CPU (integer)
//使输出的性能数据中添加 CPU 数据。
//XHPROF_FLAGS_MEMORY (integer)
//使输出的性能数据中添加内存数据。
复制

开启性能分析之后,php的代码都会被监控,进行分析运行状态

关闭性能分析

$xhprof_data = xhprof_disable();//关闭性能分析
$xhprof_runs = new \XHProfRuns_Default();
$run_id = $xhprof_runs->save_run($xhprof_data, 'your_project');//把性能分析的报告保存到output_dir目录
复制

查看性能分析:

还记得之前下载的源码吗?把里面的xhprof_html目录复制出来,单独做成一个目录,并且通过nginx或者apache配置成一个可访问的php站点:

并且把之前的xhprof_lib复制一份到同级目录:

访问这个站点:

点击查看:

这样,就可以查看到所有代码执行的cpu消耗,执行时间,占用情况了,根据这份数据,去优化最耗时间的代码即可

点击

可查看流程图:

【版权声明】本文为华为云社区用户原创内容,转载时必须标注文章的来源(华为云社区)、文章链接、文章作者等基本信息, 否则作者和本社区有权追究责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。