php 性能分析工具 xhprof 使用

本文详细介绍了在CentOS7环境下,如何安装配置XHProf性能分析工具,并结合nginx和php5.6进行测试。从下载安装包、配置PHP环境、设置nginx虚拟主机到测试文件编写,每一步都提供了具体操作步骤。最后,通过测试文件验证了XHProf的性能分析功能。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1. 环境
CentOS 7
nginx 1.14
php 5.6
2. xhprof 版本
xhprof-0.9.4

图形展示依赖:
graphviz
graphviz-gd
libpng
3. 安装 xhprof
下载 xhprof-0.9.4.tgz
tar xvzf xhprof-0.9.4.tgz
cd xhprof-0.9.4/extension
执行  /usr/local/php-fpm/bin/phpize
./configure  --with-php-config=/usr/local/php-fpm/php-config
make && make install

然后,在 php.ini 中添加 xhprof.so

vim  /usr/local/php-fpm/etc/php.ini
添加:
[xhprof]
extension=xhprof.so
xhprof.output_dir="/data/wwwroot/xhprof/output"

记得要创建 xhprof.output_dir 目录,给777 权限;
简单测试:

重启一下 php-fpm: /etc/init.d/php-fpm  restart ;
测试一下 xhprof.so 是否加载成功:
/usr/local/php-fpm/bin/php -m  | grep  xhprof
4. 为 xhprof 添加 nginx 虚拟机

在 nginx 虚拟机目录增加一个 server:


server {
        listen  80;
        server_name xhprof.dev;
        root /data/wwwroot/xhprof;
        index index.php index.html;
        access_log /data/logs/nginx/xhprof/xhprof.dev.log custom;
        error_log /data/logs/nginx/xhprof/xhprof.dev.log.err error;
        rewrite_log on;

        location ~* \.php$ {
           #fastcgi_pass   127.0.0.1:9000;
            fastcgi_pass   unix:/usr/local/php-fpm/run/php-fpm-www.sock;
            fastcgi_index  index.php;
            fastcgi_param  SCRIPT_FILENAME  $document_root$fastcgi_script_name;
            include        fastcgi_params;
        }
}

注意:

  • server_name 根据实际情况;
  • root 根据实际情况;
  • 创建日志文件路径;
  • fastcgi_pass 根据实际情况而定;
5. 测试 xhprof web

将 xhprof-0.9.4 目录下 xhprof_html 和 xhprof_lib 两个目录移动或者复制到 web 的 root 路径 /data/wwwroot/xhprof :

cp  -r /usr/local/src/xhprof-0.9.4/xhprof_html /data/wwwroot/xhprof/xhprof_html
cp  -r /usr/local/src/xhprof-0.9.4/xhprof_lib /data/wwwroot/xhprof/xhprof_lib

创建 xhprof 测试文件

cd  /data/wwwroot/xhprof/

vim  test.php

<?php

//加载所需文件
include_once "./xhprof_lib/utils/xhprof_lib.php";
include_once "./xhprof_lib/utils/xhprof_runs.php";

//随意定义一个函数
function test($max)
{
    for ($idx = 0; $idx < $max; $idx++) {
        echo '';
    }
}

//定义测试方法
function a()
{
    test(rand(1000,5000));
}

//开始分析
xhprof_enable();

//需要分析的函数
a();

//结束分析
$xhprof_data = xhprof_disable();
//实例化xhprof类
$xhprof_runs = new XHProfRuns_Default();
//获取当前当前页面分析结果
$run_id = $xhprof_runs->save_run($xhprof_data, "xhprof_foo");

echo "\nhttp://xhprof.dev/xhprof_html/index.php?run=$run_id&source=xhprof_foo\n";

测试:
在浏览器访问 http://xhprof.dev/test.php 结果:

php 性能分析工具 xhprof 使用

可以看到,返回了一个带run_id 的 url,通过这个 url 再跳转访问就可以看到具体的测试结果了:

php 性能分析工具 xhprof 使用

如果想查看图像,可以点击 [View Full Callgraph] :

php 性能分析工具 xhprof 使用

注意:

一般,大家安装完之后,系统还不能马上画图,一般会报错:

Format: "png" not recognized. Use one of: canon cmap cmapx cmapx_np dot dot_json eps fig gv imap imap_np ismap json json0 mp pic plain plain-ext pov ps ps2 svg svgz tk vml vmlz xdot xdot1.2 xdot1.4 xdot_json

解决办法:

需要安装一些依赖的工具

yum  install  graphviz
yum  install  libpng
yum  install  graphviz-gd (刚开始我没有安装这个,总是报错)

6. 总结

以上的内容只是简单安装使用 xhprof 工具,要真正用来测试 php 的性能,还需要再 php 代码中使用,如何添加结合,以后再研究。

转载于:https://blog.51cto.com/hellocjq/2329013

要在CentOS 7中的单用户模式修改密码,您可以按照以下步骤操作: 1. 首先,重启系统并进入GRUB引导菜单。您可以按下计算机的电源按钮并立即按下并持续按住Shift键,直到出现GRUB菜单为止。 2. 使用方向键选择第一个启动项,并按下e键进行编辑。 3. 找到以"linux16"开头的那一行,然后去掉其中的"rhgb"和"quiet"参数。在"UTF-8"之后添加"init=/bin/sh"参数。这将让系统在单用户模式下启动并进入一个shell提示符。 4. 按下Ctrl + x键启动修改。 5. 您现在将进入一个单用户模式的shell提示符。输入以下命令以重新挂载根文件系统为可写模式: ``` mount -o remount,rw / ``` 6. 输入以下命令以更改root用户的密码: ``` passwd ``` 7. 按照提示输入新密码并确认。 8. 输入以下命令以重新挂载根文件系统为只读模式: ``` mount -o remount,ro / ``` 9. 输入以下命令以重启系统: ``` reboot ``` 10. 系统将重新启动并返回到正常的登录界面。 请注意,这些步骤将使您能够在CentOS 7中的单用户模式修改root用户的密码。确保您按照指示操作,并确保保护好您的密码以确保系统的安全性。 [参考文献] 提供了在GRUB引导菜单中编辑启动项的具体步骤。 提供了在单用户模式下重新挂载根文件系统为可写模式和只读模式的命令。 提供了在系统中使用命令"reboot"来重启系统的方法。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值