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 结果:
可以看到, 返回了一个带 run_id 的 url, 通过这个 url 再跳转访问就可以看到具体的测试结果了:
如果想查看图像, 可以点击 [View Full Callgraph] :
注意:
一般, 大家安装完之后, 系统还不能马上画图, 一般会报错:
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 代码中使用, 如何添加结合, 以后再研究.
来源: http://www.bubuko.com/infodetail-2880923.html