博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
php 性能分析工具 xhprof 使用
阅读量:6721 次
发布时间:2019-06-25

本文共 2305 字,大约阅读时间需要 7 分钟。

1. 环境

CentOS 7nginx 1.14php 5.6

2. xhprof 版本

xhprof-0.9.4图形展示依赖:graphvizgraphviz-gdlibpng

3. 安装 xhprof

下载 xhprof-0.9.4.tgztar xvzf xhprof-0.9.4.tgzcd xhprof-0.9.4/extension执行  /usr/local/php-fpm/bin/phpize./configure  --with-php-config=/usr/local/php-fpm/php-configmake && make install

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

vim  /usr/local/php-fpm/etc/php.ini添加:[xhprof]extension=xhprof.soxhprof.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_htmlcp  -r /usr/local/src/xhprof-0.9.4/xhprof_lib /data/wwwroot/xhprof/xhprof_lib

创建 xhprof 测试文件

cd  /data/wwwroot/xhprof/vim  test.php
save_run($xhprof_data, "xhprof_foo");echo "\nhttp://xhprof.dev/xhprof_html/index.php?run=$run_id&source=xhprof_foo\n";

测试:

在浏览器访问 结果:

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  graphvizyum  install  libpngyum  install  graphviz-gd (刚开始我没有安装这个,总是报错)

6. 总结

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

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

你可能感兴趣的文章
Python中用datetime包进行对时间的一些操作
查看>>
Web.xml配置详解之context-param
查看>>
WIKI扫盲手册
查看>>
Javascript - ExtJs - 整合百度文章编辑器
查看>>
JS分两种数据类型,你都知道吗?
查看>>
Bash条件判断
查看>>
JSF 2.0 + Ajax hello world example
查看>>
Firefox 插件 FlashGot 创建 Axel 下载任务
查看>>
php中相对路径和绝对路径如何使用(详解)
查看>>
Oracle 数据库、实例、用户、表空间、表之间的关系
查看>>
RVM 多版本Ruby管理-Gentoo
查看>>
android error: Apostrophe not preceded by \
查看>>
小程序-scroll-view下拉事件请求多次接口
查看>>
AngularJs 指令
查看>>
云适配正则笔记
查看>>
开始学习silverlight
查看>>
php使用递归计算目录大小
查看>>
EF 直接修改数据,不再查询数据库
查看>>
script标签加载js代码的一些知识
查看>>
The builder launch configuration could not be found
查看>>